| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065306630673068306930703071307230733074307530763077307830793080308130823083308430853086308730883089309030913092309330943095309630973098309931003101310231033104310531063107310831093110311131123113311431153116311731183119312031213122312331243125312631273128312931303131313231333134313531363137313831393140314131423143314431453146314731483149315031513152315331543155315631573158315931603161316231633164316531663167316831693170317131723173317431753176317731783179318031813182318331843185318631873188318931903191319231933194319531963197319831993200320132023203320432053206320732083209321032113212321332143215321632173218321932203221322232233224322532263227322832293230323132323233323432353236323732383239324032413242324332443245324632473248324932503251325232533254325532563257325832593260326132623263326432653266326732683269327032713272327332743275327632773278327932803281328232833284328532863287328832893290329132923293329432953296329732983299330033013302330333043305330633073308330933103311331233133314331533163317331833193320332133223323332433253326332733283329333033313332333333343335333633373338333933403341334233433344334533463347334833493350335133523353335433553356335733583359336033613362336333643365336633673368336933703371337233733374337533763377337833793380338133823383338433853386338733883389339033913392339333943395339633973398339934003401340234033404340534063407340834093410341134123413341434153416341734183419342034213422342334243425342634273428342934303431343234333434343534363437343834393440344134423443344434453446344734483449345034513452345334543455345634573458345934603461346234633464346534663467346834693470347134723473347434753476347734783479348034813482348334843485348634873488348934903491349234933494349534963497349834993500350135023503350435053506350735083509351035113512351335143515351635173518351935203521352235233524352535263527352835293530353135323533353435353536353735383539354035413542354335443545354635473548354935503551355235533554355535563557355835593560356135623563356435653566356735683569357035713572357335743575357635773578357935803581358235833584358535863587358835893590359135923593359435953596359735983599360036013602360336043605360636073608360936103611361236133614361536163617361836193620362136223623362436253626362736283629363036313632363336343635363636373638363936403641364236433644364536463647364836493650365136523653365436553656365736583659366036613662366336643665366636673668366936703671367236733674367536763677367836793680368136823683368436853686368736883689369036913692369336943695369636973698369937003701370237033704370537063707370837093710371137123713371437153716371737183719372037213722372337243725372637273728372937303731373237333734373537363737373837393740374137423743374437453746374737483749375037513752375337543755375637573758375937603761376237633764376537663767376837693770377137723773377437753776377737783779378037813782378337843785378637873788378937903791379237933794379537963797379837993800380138023803380438053806380738083809381038113812381338143815381638173818381938203821382238233824382538263827382838293830383138323833383438353836383738383839384038413842384338443845384638473848384938503851385238533854385538563857385838593860386138623863386438653866386738683869387038713872387338743875387638773878387938803881388238833884388538863887388838893890389138923893389438953896389738983899390039013902390339043905390639073908390939103911391239133914391539163917391839193920392139223923392439253926392739283929393039313932393339343935393639373938393939403941394239433944394539463947394839493950395139523953395439553956395739583959396039613962396339643965396639673968396939703971397239733974397539763977397839793980398139823983398439853986398739883989399039913992399339943995399639973998399940004001400240034004400540064007400840094010401140124013401440154016401740184019402040214022402340244025402640274028402940304031403240334034403540364037403840394040404140424043404440454046404740484049405040514052405340544055405640574058405940604061406240634064406540664067406840694070407140724073407440754076407740784079408040814082408340844085408640874088408940904091409240934094409540964097409840994100410141024103410441054106410741084109411041114112411341144115411641174118411941204121412241234124412541264127412841294130413141324133413441354136413741384139414041414142414341444145414641474148414941504151415241534154415541564157415841594160416141624163416441654166416741684169417041714172417341744175417641774178417941804181418241834184418541864187418841894190419141924193419441954196419741984199420042014202420342044205420642074208420942104211421242134214421542164217421842194220422142224223422442254226422742284229423042314232423342344235423642374238423942404241424242434244424542464247424842494250425142524253425442554256425742584259426042614262426342644265426642674268426942704271427242734274427542764277427842794280428142824283428442854286428742884289429042914292429342944295429642974298429943004301430243034304430543064307430843094310431143124313431443154316431743184319432043214322432343244325432643274328432943304331433243334334433543364337433843394340434143424343434443454346434743484349435043514352435343544355435643574358435943604361436243634364436543664367436843694370437143724373437443754376437743784379438043814382438343844385438643874388438943904391439243934394439543964397439843994400440144024403440444054406440744084409441044114412441344144415441644174418441944204421442244234424442544264427442844294430443144324433443444354436443744384439444044414442444344444445444644474448444944504451445244534454445544564457445844594460446144624463446444654466446744684469447044714472447344744475447644774478447944804481448244834484448544864487448844894490449144924493449444954496449744984499450045014502450345044505450645074508450945104511451245134514451545164517451845194520452145224523452445254526452745284529453045314532453345344535453645374538453945404541454245434544454545464547454845494550455145524553455445554556455745584559456045614562456345644565456645674568456945704571457245734574457545764577457845794580458145824583458445854586458745884589459045914592459345944595459645974598459946004601460246034604460546064607460846094610461146124613461446154616461746184619462046214622462346244625462646274628462946304631463246334634463546364637463846394640464146424643464446454646464746484649465046514652465346544655465646574658465946604661466246634664466546664667466846694670467146724673467446754676467746784679468046814682468346844685468646874688468946904691469246934694469546964697469846994700470147024703470447054706470747084709471047114712471347144715471647174718471947204721472247234724472547264727472847294730473147324733473447354736473747384739474047414742474347444745474647474748474947504751475247534754475547564757475847594760476147624763476447654766476747684769477047714772477347744775477647774778477947804781478247834784478547864787478847894790479147924793479447954796479747984799480048014802480348044805480648074808480948104811481248134814481548164817481848194820482148224823482448254826482748284829483048314832483348344835483648374838483948404841484248434844484548464847484848494850485148524853485448554856485748584859486048614862486348644865486648674868486948704871487248734874487548764877487848794880488148824883488448854886488748884889489048914892489348944895489648974898489949004901490249034904490549064907490849094910491149124913491449154916491749184919492049214922492349244925492649274928492949304931493249334934493549364937493849394940494149424943494449454946494749484949495049514952495349544955495649574958495949604961496249634964496549664967496849694970497149724973497449754976497749784979498049814982498349844985498649874988498949904991499249934994499549964997499849995000500150025003500450055006500750085009501050115012501350145015501650175018501950205021502250235024502550265027502850295030503150325033503450355036503750385039504050415042504350445045504650475048504950505051505250535054505550565057505850595060506150625063506450655066506750685069507050715072507350745075507650775078507950805081508250835084508550865087508850895090509150925093509450955096509750985099510051015102510351045105510651075108510951105111511251135114511551165117511851195120512151225123512451255126512751285129513051315132513351345135513651375138513951405141514251435144514551465147514851495150515151525153515451555156515751585159516051615162516351645165516651675168516951705171517251735174517551765177517851795180518151825183518451855186518751885189519051915192519351945195519651975198519952005201520252035204520552065207520852095210521152125213521452155216521752185219522052215222522352245225522652275228522952305231523252335234523552365237523852395240524152425243524452455246524752485249525052515252525352545255525652575258525952605261526252635264526552665267526852695270527152725273527452755276527752785279528052815282528352845285528652875288528952905291529252935294529552965297529852995300530153025303530453055306530753085309531053115312531353145315531653175318531953205321532253235324532553265327532853295330533153325333533453355336533753385339534053415342534353445345534653475348534953505351535253535354535553565357535853595360536153625363536453655366536753685369537053715372537353745375537653775378537953805381538253835384538553865387538853895390539153925393539453955396539753985399540054015402540354045405540654075408540954105411541254135414541554165417541854195420542154225423542454255426542754285429543054315432543354345435543654375438543954405441544254435444544554465447544854495450545154525453545454555456545754585459546054615462546354645465546654675468546954705471547254735474547554765477547854795480548154825483548454855486548754885489549054915492549354945495549654975498549955005501550255035504550555065507550855095510551155125513551455155516551755185519552055215522552355245525552655275528552955305531553255335534553555365537553855395540554155425543554455455546554755485549555055515552555355545555555655575558555955605561556255635564556555665567556855695570557155725573557455755576557755785579558055815582558355845585558655875588558955905591559255935594559555965597559855995600560156025603560456055606560756085609561056115612561356145615561656175618561956205621562256235624562556265627562856295630563156325633563456355636563756385639564056415642564356445645564656475648564956505651565256535654565556565657565856595660566156625663566456655666566756685669567056715672567356745675567656775678567956805681568256835684568556865687568856895690569156925693569456955696569756985699570057015702570357045705570657075708570957105711571257135714571557165717571857195720572157225723572457255726572757285729573057315732573357345735573657375738573957405741574257435744574557465747574857495750575157525753575457555756575757585759576057615762576357645765576657675768576957705771577257735774577557765777577857795780578157825783578457855786578757885789579057915792579357945795579657975798579958005801580258035804580558065807580858095810581158125813581458155816581758185819582058215822582358245825582658275828582958305831583258335834583558365837583858395840584158425843584458455846584758485849585058515852585358545855585658575858585958605861586258635864586558665867586858695870587158725873587458755876587758785879588058815882588358845885588658875888588958905891589258935894589558965897589858995900590159025903590459055906590759085909591059115912591359145915591659175918591959205921592259235924592559265927592859295930593159325933593459355936593759385939594059415942594359445945594659475948594959505951595259535954595559565957595859595960596159625963596459655966596759685969597059715972597359745975597659775978597959805981598259835984598559865987598859895990599159925993599459955996599759985999600060016002600360046005600660076008600960106011601260136014601560166017601860196020602160226023602460256026602760286029603060316032603360346035603660376038603960406041604260436044604560466047604860496050605160526053605460556056605760586059606060616062606360646065606660676068606960706071607260736074607560766077607860796080608160826083608460856086608760886089609060916092609360946095609660976098609961006101610261036104610561066107610861096110611161126113611461156116611761186119612061216122612361246125612661276128612961306131613261336134613561366137613861396140614161426143614461456146614761486149615061516152615361546155615661576158615961606161616261636164616561666167616861696170617161726173617461756176617761786179618061816182618361846185618661876188618961906191619261936194619561966197619861996200620162026203620462056206620762086209621062116212621362146215621662176218621962206221622262236224622562266227622862296230623162326233623462356236623762386239624062416242624362446245624662476248624962506251625262536254625562566257625862596260626162626263626462656266626762686269627062716272627362746275627662776278627962806281628262836284628562866287628862896290629162926293629462956296629762986299630063016302630363046305630663076308630963106311631263136314631563166317631863196320632163226323632463256326632763286329633063316332633363346335633663376338633963406341634263436344634563466347634863496350635163526353635463556356635763586359636063616362636363646365636663676368636963706371637263736374637563766377637863796380638163826383638463856386638763886389639063916392639363946395639663976398639964006401640264036404640564066407640864096410641164126413641464156416641764186419642064216422642364246425642664276428642964306431643264336434643564366437643864396440644164426443644464456446644764486449645064516452645364546455645664576458645964606461646264636464646564666467646864696470647164726473647464756476647764786479648064816482648364846485648664876488648964906491649264936494649564966497649864996500650165026503650465056506650765086509651065116512651365146515651665176518651965206521652265236524652565266527652865296530653165326533653465356536653765386539654065416542654365446545654665476548654965506551655265536554655565566557655865596560656165626563656465656566656765686569657065716572657365746575657665776578657965806581658265836584658565866587658865896590659165926593659465956596659765986599660066016602660366046605660666076608660966106611661266136614661566166617661866196620662166226623662466256626662766286629663066316632663366346635663666376638663966406641664266436644664566466647664866496650665166526653665466556656665766586659666066616662666366646665666666676668666966706671667266736674667566766677667866796680668166826683668466856686668766886689669066916692669366946695669666976698669967006701670267036704670567066707670867096710671167126713671467156716671767186719672067216722672367246725672667276728672967306731673267336734673567366737673867396740674167426743674467456746674767486749675067516752675367546755675667576758675967606761676267636764676567666767676867696770677167726773677467756776677767786779678067816782678367846785678667876788678967906791679267936794679567966797679867996800680168026803680468056806680768086809681068116812681368146815681668176818681968206821682268236824682568266827682868296830683168326833683468356836683768386839684068416842684368446845684668476848684968506851685268536854685568566857685868596860686168626863686468656866686768686869687068716872687368746875687668776878687968806881688268836884688568866887688868896890689168926893689468956896689768986899690069016902690369046905690669076908690969106911691269136914691569166917691869196920692169226923692469256926692769286929693069316932693369346935693669376938693969406941694269436944694569466947694869496950695169526953695469556956695769586959696069616962696369646965696669676968696969706971697269736974697569766977697869796980698169826983698469856986698769886989699069916992699369946995699669976998699970007001700270037004700570067007700870097010701170127013701470157016701770187019702070217022702370247025702670277028702970307031703270337034703570367037703870397040704170427043704470457046704770487049705070517052705370547055705670577058705970607061706270637064706570667067706870697070707170727073707470757076707770787079708070817082708370847085708670877088708970907091709270937094709570967097709870997100710171027103710471057106710771087109711071117112711371147115711671177118711971207121712271237124712571267127712871297130713171327133713471357136713771387139714071417142714371447145714671477148714971507151715271537154715571567157715871597160716171627163716471657166716771687169717071717172717371747175717671777178717971807181718271837184718571867187718871897190719171927193719471957196719771987199720072017202720372047205720672077208720972107211721272137214721572167217721872197220722172227223722472257226722772287229723072317232723372347235723672377238723972407241724272437244724572467247724872497250725172527253725472557256725772587259726072617262726372647265726672677268726972707271727272737274727572767277727872797280728172827283728472857286728772887289729072917292729372947295729672977298729973007301730273037304730573067307730873097310731173127313731473157316731773187319732073217322732373247325732673277328732973307331733273337334733573367337733873397340734173427343734473457346734773487349735073517352735373547355735673577358735973607361736273637364736573667367736873697370737173727373737473757376737773787379738073817382738373847385738673877388738973907391739273937394739573967397739873997400740174027403740474057406740774087409741074117412741374147415741674177418741974207421742274237424742574267427742874297430743174327433743474357436743774387439744074417442744374447445744674477448744974507451745274537454745574567457745874597460746174627463746474657466746774687469747074717472747374747475747674777478747974807481748274837484748574867487748874897490749174927493749474957496749774987499750075017502750375047505750675077508750975107511751275137514751575167517751875197520752175227523752475257526752775287529753075317532753375347535753675377538753975407541754275437544754575467547754875497550755175527553755475557556755775587559756075617562756375647565756675677568756975707571757275737574757575767577757875797580758175827583758475857586758775887589759075917592759375947595759675977598759976007601760276037604760576067607760876097610761176127613761476157616761776187619762076217622762376247625762676277628762976307631763276337634763576367637763876397640764176427643764476457646764776487649765076517652765376547655765676577658765976607661766276637664766576667667766876697670767176727673767476757676767776787679768076817682768376847685768676877688768976907691769276937694769576967697769876997700770177027703770477057706770777087709771077117712771377147715771677177718771977207721772277237724772577267727772877297730773177327733773477357736773777387739774077417742774377447745774677477748774977507751775277537754775577567757775877597760776177627763776477657766776777687769777077717772777377747775777677777778777977807781778277837784778577867787778877897790779177927793779477957796779777987799780078017802780378047805780678077808780978107811781278137814781578167817781878197820782178227823782478257826782778287829783078317832783378347835783678377838783978407841784278437844784578467847784878497850785178527853785478557856785778587859786078617862786378647865786678677868786978707871787278737874787578767877787878797880788178827883788478857886788778887889789078917892789378947895789678977898789979007901790279037904790579067907790879097910791179127913791479157916791779187919792079217922792379247925792679277928792979307931793279337934793579367937793879397940794179427943794479457946794779487949795079517952795379547955795679577958795979607961796279637964796579667967796879697970797179727973797479757976797779787979798079817982798379847985798679877988798979907991799279937994799579967997799879998000800180028003800480058006800780088009801080118012801380148015801680178018801980208021802280238024802580268027802880298030803180328033803480358036803780388039804080418042804380448045804680478048804980508051805280538054805580568057805880598060806180628063806480658066806780688069807080718072807380748075807680778078807980808081808280838084808580868087808880898090809180928093809480958096809780988099810081018102810381048105810681078108810981108111811281138114811581168117811881198120812181228123812481258126812781288129813081318132813381348135813681378138813981408141814281438144814581468147814881498150815181528153815481558156815781588159816081618162816381648165816681678168816981708171817281738174817581768177817881798180818181828183818481858186818781888189819081918192819381948195819681978198819982008201820282038204820582068207820882098210821182128213821482158216821782188219822082218222822382248225822682278228822982308231823282338234823582368237823882398240824182428243824482458246824782488249825082518252825382548255825682578258825982608261826282638264826582668267826882698270827182728273827482758276827782788279828082818282828382848285828682878288828982908291829282938294829582968297829882998300830183028303830483058306830783088309831083118312831383148315831683178318831983208321832283238324832583268327832883298330833183328333833483358336833783388339834083418342834383448345834683478348834983508351835283538354835583568357835883598360836183628363836483658366836783688369837083718372837383748375837683778378837983808381838283838384838583868387838883898390839183928393839483958396839783988399840084018402840384048405840684078408840984108411841284138414841584168417841884198420842184228423842484258426842784288429843084318432843384348435843684378438843984408441844284438444844584468447844884498450845184528453845484558456845784588459846084618462846384648465846684678468846984708471847284738474847584768477847884798480848184828483848484858486848784888489849084918492849384948495849684978498849985008501850285038504850585068507850885098510851185128513851485158516851785188519852085218522852385248525852685278528852985308531853285338534853585368537853885398540854185428543854485458546854785488549855085518552855385548555855685578558855985608561856285638564856585668567856885698570857185728573857485758576857785788579858085818582858385848585858685878588858985908591859285938594859585968597859885998600860186028603860486058606860786088609861086118612861386148615861686178618861986208621862286238624862586268627862886298630863186328633863486358636863786388639864086418642864386448645864686478648864986508651865286538654865586568657865886598660866186628663866486658666866786688669867086718672867386748675867686778678867986808681868286838684868586868687868886898690869186928693869486958696869786988699870087018702870387048705870687078708870987108711871287138714871587168717871887198720872187228723872487258726872787288729873087318732873387348735873687378738873987408741874287438744874587468747874887498750875187528753875487558756875787588759876087618762876387648765876687678768876987708771877287738774877587768777877887798780878187828783878487858786878787888789879087918792879387948795879687978798879988008801880288038804880588068807880888098810881188128813881488158816881788188819882088218822882388248825882688278828882988308831883288338834883588368837883888398840884188428843884488458846884788488849885088518852885388548855885688578858885988608861886288638864886588668867886888698870887188728873887488758876887788788879888088818882888388848885888688878888888988908891889288938894889588968897889888998900890189028903890489058906890789088909891089118912891389148915891689178918891989208921892289238924892589268927892889298930893189328933893489358936893789388939894089418942894389448945894689478948894989508951895289538954895589568957895889598960896189628963896489658966896789688969897089718972897389748975897689778978897989808981898289838984898589868987898889898990899189928993899489958996899789988999900090019002900390049005900690079008900990109011901290139014901590169017901890199020902190229023902490259026902790289029903090319032903390349035903690379038903990409041904290439044904590469047904890499050905190529053905490559056905790589059906090619062906390649065906690679068906990709071907290739074907590769077907890799080908190829083908490859086908790889089909090919092909390949095909690979098909991009101910291039104910591069107910891099110911191129113911491159116911791189119912091219122912391249125912691279128912991309131913291339134913591369137913891399140914191429143914491459146914791489149915091519152915391549155915691579158915991609161916291639164916591669167916891699170917191729173917491759176917791789179918091819182918391849185918691879188918991909191919291939194919591969197919891999200920192029203920492059206920792089209921092119212921392149215921692179218921992209221922292239224922592269227922892299230923192329233923492359236923792389239924092419242924392449245924692479248924992509251925292539254925592569257925892599260926192629263926492659266926792689269927092719272927392749275927692779278927992809281928292839284928592869287928892899290929192929293929492959296929792989299930093019302930393049305930693079308930993109311931293139314931593169317931893199320932193229323932493259326932793289329933093319332933393349335933693379338933993409341934293439344934593469347934893499350935193529353935493559356935793589359936093619362936393649365936693679368936993709371937293739374937593769377937893799380938193829383938493859386938793889389939093919392939393949395939693979398939994009401940294039404940594069407940894099410941194129413941494159416941794189419942094219422942394249425942694279428942994309431943294339434943594369437943894399440944194429443944494459446944794489449945094519452945394549455945694579458945994609461946294639464946594669467946894699470947194729473947494759476947794789479948094819482948394849485948694879488948994909491949294939494949594969497949894999500950195029503950495059506950795089509951095119512951395149515951695179518951995209521952295239524952595269527952895299530953195329533953495359536953795389539954095419542954395449545954695479548954995509551955295539554955595569557955895599560956195629563956495659566956795689569957095719572957395749575957695779578957995809581958295839584958595869587958895899590959195929593959495959596959795989599960096019602960396049605960696079608960996109611961296139614961596169617961896199620962196229623962496259626962796289629963096319632963396349635963696379638963996409641964296439644964596469647964896499650965196529653965496559656965796589659966096619662966396649665966696679668966996709671967296739674967596769677967896799680968196829683968496859686968796889689969096919692969396949695969696979698969997009701970297039704970597069707970897099710971197129713971497159716971797189719972097219722972397249725972697279728972997309731973297339734973597369737973897399740974197429743974497459746974797489749975097519752975397549755975697579758975997609761976297639764976597669767976897699770977197729773977497759776977797789779978097819782978397849785978697879788978997909791979297939794979597969797979897999800980198029803980498059806980798089809981098119812981398149815981698179818981998209821982298239824982598269827982898299830983198329833983498359836983798389839984098419842984398449845984698479848984998509851985298539854985598569857985898599860986198629863986498659866986798689869987098719872987398749875987698779878987998809881988298839884988598869887988898899890989198929893989498959896989798989899990099019902990399049905990699079908990999109911991299139914991599169917991899199920992199229923992499259926992799289929993099319932993399349935993699379938993999409941994299439944994599469947994899499950995199529953995499559956995799589959996099619962996399649965996699679968996999709971997299739974997599769977997899799980998199829983998499859986998799889989999099919992999399949995999699979998999910000100011000210003100041000510006100071000810009100101001110012100131001410015100161001710018100191002010021100221002310024100251002610027100281002910030100311003210033100341003510036100371003810039100401004110042100431004410045100461004710048100491005010051100521005310054100551005610057100581005910060100611006210063100641006510066100671006810069100701007110072100731007410075100761007710078100791008010081100821008310084100851008610087100881008910090100911009210093100941009510096100971009810099101001010110102101031010410105101061010710108101091011010111101121011310114101151011610117101181011910120101211012210123101241012510126101271012810129101301013110132101331013410135101361013710138101391014010141101421014310144101451014610147101481014910150101511015210153101541015510156101571015810159101601016110162101631016410165101661016710168101691017010171101721017310174101751017610177101781017910180101811018210183101841018510186101871018810189101901019110192101931019410195101961019710198101991020010201102021020310204102051020610207102081020910210102111021210213102141021510216102171021810219102201022110222102231022410225102261022710228102291023010231102321023310234102351023610237102381023910240102411024210243102441024510246102471024810249102501025110252102531025410255102561025710258102591026010261102621026310264102651026610267102681026910270102711027210273102741027510276102771027810279102801028110282102831028410285102861028710288102891029010291102921029310294102951029610297102981029910300103011030210303103041030510306103071030810309103101031110312103131031410315103161031710318103191032010321103221032310324103251032610327103281032910330103311033210333103341033510336103371033810339103401034110342103431034410345103461034710348103491035010351103521035310354103551035610357103581035910360103611036210363103641036510366103671036810369103701037110372103731037410375103761037710378103791038010381103821038310384103851038610387103881038910390103911039210393103941039510396103971039810399104001040110402104031040410405104061040710408104091041010411104121041310414104151041610417104181041910420104211042210423104241042510426104271042810429104301043110432104331043410435104361043710438104391044010441104421044310444104451044610447104481044910450104511045210453104541045510456104571045810459104601046110462104631046410465104661046710468104691047010471104721047310474104751047610477104781047910480104811048210483104841048510486104871048810489104901049110492104931049410495104961049710498104991050010501105021050310504105051050610507105081050910510105111051210513105141051510516105171051810519105201052110522105231052410525105261052710528105291053010531105321053310534105351053610537105381053910540105411054210543105441054510546105471054810549105501055110552105531055410555105561055710558105591056010561105621056310564105651056610567105681056910570105711057210573105741057510576105771057810579105801058110582105831058410585105861058710588105891059010591105921059310594105951059610597105981059910600106011060210603106041060510606106071060810609106101061110612106131061410615106161061710618106191062010621106221062310624106251062610627106281062910630106311063210633106341063510636106371063810639106401064110642106431064410645106461064710648106491065010651106521065310654106551065610657106581065910660106611066210663106641066510666106671066810669106701067110672106731067410675106761067710678106791068010681106821068310684106851068610687106881068910690106911069210693106941069510696106971069810699107001070110702107031070410705107061070710708107091071010711107121071310714107151071610717107181071910720107211072210723107241072510726107271072810729107301073110732107331073410735107361073710738107391074010741107421074310744107451074610747107481074910750107511075210753107541075510756107571075810759107601076110762107631076410765107661076710768107691077010771107721077310774107751077610777107781077910780107811078210783107841078510786107871078810789107901079110792107931079410795107961079710798107991080010801108021080310804108051080610807108081080910810108111081210813108141081510816108171081810819108201082110822108231082410825108261082710828108291083010831108321083310834108351083610837108381083910840108411084210843108441084510846108471084810849108501085110852108531085410855108561085710858108591086010861108621086310864108651086610867108681086910870108711087210873108741087510876108771087810879108801088110882108831088410885108861088710888108891089010891108921089310894108951089610897108981089910900109011090210903109041090510906109071090810909109101091110912109131091410915109161091710918109191092010921109221092310924109251092610927109281092910930109311093210933109341093510936109371093810939109401094110942109431094410945109461094710948109491095010951109521095310954109551095610957109581095910960109611096210963109641096510966109671096810969109701097110972109731097410975109761097710978109791098010981109821098310984109851098610987109881098910990109911099210993109941099510996109971099810999110001100111002110031100411005110061100711008110091101011011110121101311014110151101611017110181101911020110211102211023110241102511026110271102811029110301103111032110331103411035110361103711038110391104011041110421104311044110451104611047110481104911050110511105211053110541105511056110571105811059110601106111062110631106411065110661106711068110691107011071110721107311074110751107611077110781107911080110811108211083110841108511086110871108811089110901109111092110931109411095110961109711098110991110011101111021110311104111051110611107111081110911110111111111211113111141111511116111171111811119111201112111122111231112411125111261112711128111291113011131111321113311134111351113611137111381113911140111411114211143111441114511146111471114811149111501115111152111531115411155111561115711158111591116011161111621116311164111651116611167111681116911170111711117211173111741117511176111771117811179111801118111182111831118411185111861118711188111891119011191111921119311194111951119611197111981119911200112011120211203112041120511206112071120811209112101121111212112131121411215112161121711218112191122011221112221122311224112251122611227112281122911230112311123211233112341123511236112371123811239112401124111242112431124411245112461124711248112491125011251112521125311254112551125611257112581125911260112611126211263112641126511266112671126811269112701127111272112731127411275112761127711278112791128011281112821128311284112851128611287112881128911290112911129211293112941129511296112971129811299113001130111302113031130411305113061130711308113091131011311113121131311314113151131611317113181131911320113211132211323113241132511326113271132811329113301133111332113331133411335113361133711338113391134011341113421134311344113451134611347113481134911350113511135211353113541135511356113571135811359113601136111362113631136411365113661136711368113691137011371113721137311374113751137611377113781137911380113811138211383113841138511386113871138811389113901139111392113931139411395113961139711398113991140011401114021140311404114051140611407114081140911410114111141211413114141141511416114171141811419114201142111422114231142411425114261142711428114291143011431114321143311434114351143611437114381143911440114411144211443114441144511446114471144811449114501145111452114531145411455114561145711458114591146011461114621146311464114651146611467114681146911470114711147211473114741147511476114771147811479114801148111482114831148411485114861148711488114891149011491114921149311494114951149611497114981149911500115011150211503115041150511506115071150811509115101151111512115131151411515115161151711518115191152011521115221152311524115251152611527115281152911530115311153211533115341153511536115371153811539115401154111542115431154411545115461154711548115491155011551115521155311554115551155611557115581155911560115611156211563115641156511566115671156811569115701157111572115731157411575115761157711578115791158011581115821158311584115851158611587115881158911590115911159211593115941159511596115971159811599116001160111602116031160411605116061160711608116091161011611116121161311614116151161611617116181161911620116211162211623116241162511626116271162811629116301163111632116331163411635116361163711638116391164011641116421164311644116451164611647116481164911650116511165211653116541165511656116571165811659116601166111662116631166411665116661166711668116691167011671116721167311674116751167611677116781167911680116811168211683116841168511686116871168811689116901169111692116931169411695116961169711698116991170011701117021170311704117051170611707117081170911710117111171211713117141171511716117171171811719117201172111722117231172411725117261172711728117291173011731117321173311734117351173611737117381173911740117411174211743117441174511746117471174811749117501175111752117531175411755117561175711758117591176011761117621176311764117651176611767117681176911770117711177211773117741177511776117771177811779117801178111782117831178411785117861178711788117891179011791117921179311794117951179611797117981179911800118011180211803118041180511806118071180811809118101181111812118131181411815118161181711818118191182011821118221182311824118251182611827118281182911830118311183211833118341183511836118371183811839118401184111842118431184411845118461184711848118491185011851118521185311854118551185611857118581185911860118611186211863118641186511866118671186811869118701187111872118731187411875118761187711878118791188011881118821188311884118851188611887118881188911890118911189211893118941189511896118971189811899119001190111902119031190411905119061190711908119091191011911119121191311914119151191611917119181191911920119211192211923119241192511926119271192811929119301193111932119331193411935119361193711938119391194011941119421194311944119451194611947119481194911950119511195211953119541195511956119571195811959119601196111962119631196411965119661196711968119691197011971119721197311974119751197611977119781197911980119811198211983119841198511986119871198811989119901199111992119931199411995119961199711998119991200012001120021200312004120051200612007120081200912010120111201212013120141201512016120171201812019120201202112022120231202412025120261202712028120291203012031120321203312034120351203612037120381203912040120411204212043120441204512046120471204812049120501205112052120531205412055120561205712058120591206012061120621206312064120651206612067120681206912070120711207212073120741207512076120771207812079120801208112082120831208412085120861208712088120891209012091120921209312094120951209612097120981209912100121011210212103121041210512106121071210812109121101211112112121131211412115121161211712118121191212012121121221212312124121251212612127121281212912130121311213212133121341213512136121371213812139121401214112142121431214412145121461214712148121491215012151121521215312154121551215612157121581215912160121611216212163121641216512166121671216812169121701217112172121731217412175121761217712178121791218012181121821218312184121851218612187121881218912190121911219212193121941219512196121971219812199122001220112202122031220412205122061220712208122091221012211122121221312214122151221612217122181221912220122211222212223122241222512226122271222812229122301223112232122331223412235122361223712238122391224012241122421224312244122451224612247122481224912250122511225212253122541225512256122571225812259122601226112262122631226412265122661226712268122691227012271122721227312274122751227612277122781227912280122811228212283122841228512286122871228812289122901229112292122931229412295122961229712298122991230012301123021230312304123051230612307123081230912310123111231212313123141231512316123171231812319123201232112322123231232412325123261232712328123291233012331123321233312334123351233612337123381233912340123411234212343123441234512346123471234812349123501235112352123531235412355123561235712358123591236012361123621236312364123651236612367123681236912370123711237212373123741237512376123771237812379123801238112382123831238412385123861238712388123891239012391123921239312394123951239612397123981239912400124011240212403124041240512406124071240812409124101241112412124131241412415124161241712418124191242012421124221242312424124251242612427124281242912430124311243212433124341243512436124371243812439124401244112442124431244412445124461244712448124491245012451124521245312454124551245612457124581245912460124611246212463124641246512466124671246812469124701247112472124731247412475124761247712478124791248012481124821248312484124851248612487124881248912490124911249212493124941249512496124971249812499125001250112502125031250412505125061250712508125091251012511125121251312514125151251612517125181251912520125211252212523125241252512526125271252812529125301253112532125331253412535125361253712538125391254012541125421254312544125451254612547125481254912550125511255212553125541255512556125571255812559125601256112562125631256412565125661256712568125691257012571125721257312574125751257612577125781257912580125811258212583125841258512586125871258812589125901259112592125931259412595125961259712598125991260012601126021260312604126051260612607126081260912610126111261212613126141261512616126171261812619126201262112622126231262412625126261262712628126291263012631126321263312634126351263612637126381263912640126411264212643126441264512646126471264812649126501265112652126531265412655126561265712658126591266012661126621266312664126651266612667126681266912670126711267212673126741267512676126771267812679126801268112682126831268412685126861268712688126891269012691126921269312694126951269612697126981269912700127011270212703127041270512706127071270812709127101271112712127131271412715127161271712718127191272012721127221272312724127251272612727127281272912730127311273212733127341273512736127371273812739127401274112742127431274412745127461274712748127491275012751127521275312754127551275612757127581275912760127611276212763127641276512766127671276812769127701277112772127731277412775127761277712778127791278012781127821278312784127851278612787127881278912790127911279212793127941279512796127971279812799128001280112802128031280412805128061280712808128091281012811128121281312814128151281612817128181281912820128211282212823128241282512826128271282812829128301283112832128331283412835128361283712838128391284012841128421284312844128451284612847128481284912850128511285212853128541285512856128571285812859128601286112862128631286412865128661286712868128691287012871128721287312874128751287612877128781287912880128811288212883128841288512886128871288812889128901289112892128931289412895128961289712898128991290012901129021290312904129051290612907129081290912910129111291212913129141291512916129171291812919129201292112922129231292412925129261292712928129291293012931129321293312934129351293612937129381293912940129411294212943129441294512946129471294812949129501295112952129531295412955129561295712958129591296012961129621296312964129651296612967129681296912970129711297212973129741297512976129771297812979129801298112982129831298412985129861298712988129891299012991129921299312994129951299612997129981299913000130011300213003130041300513006130071300813009130101301113012130131301413015130161301713018130191302013021130221302313024130251302613027130281302913030130311303213033130341303513036130371303813039130401304113042130431304413045130461304713048130491305013051130521305313054130551305613057130581305913060130611306213063130641306513066130671306813069130701307113072130731307413075130761307713078130791308013081130821308313084130851308613087130881308913090130911309213093130941309513096130971309813099131001310113102131031310413105131061310713108131091311013111131121311313114131151311613117131181311913120131211312213123131241312513126131271312813129131301313113132131331313413135131361313713138131391314013141131421314313144131451314613147131481314913150131511315213153131541315513156131571315813159131601316113162131631316413165131661316713168131691317013171131721317313174131751317613177131781317913180131811318213183131841318513186131871318813189131901319113192131931319413195131961319713198131991320013201132021320313204132051320613207132081320913210132111321213213132141321513216132171321813219132201322113222132231322413225132261322713228132291323013231132321323313234132351323613237132381323913240132411324213243132441324513246132471324813249132501325113252132531325413255132561325713258132591326013261132621326313264132651326613267132681326913270132711327213273132741327513276132771327813279132801328113282132831328413285132861328713288132891329013291132921329313294132951329613297132981329913300133011330213303133041330513306133071330813309133101331113312133131331413315133161331713318133191332013321133221332313324133251332613327133281332913330133311333213333133341333513336133371333813339133401334113342133431334413345133461334713348133491335013351133521335313354133551335613357133581335913360133611336213363133641336513366133671336813369133701337113372133731337413375133761337713378133791338013381133821338313384133851338613387133881338913390133911339213393133941339513396133971339813399134001340113402134031340413405134061340713408134091341013411134121341313414134151341613417134181341913420134211342213423134241342513426134271342813429134301343113432134331343413435134361343713438134391344013441134421344313444134451344613447134481344913450134511345213453134541345513456134571345813459134601346113462134631346413465134661346713468134691347013471134721347313474134751347613477134781347913480134811348213483134841348513486134871348813489134901349113492134931349413495134961349713498134991350013501135021350313504135051350613507135081350913510135111351213513135141351513516135171351813519135201352113522135231352413525135261352713528135291353013531135321353313534135351353613537135381353913540135411354213543135441354513546135471354813549135501355113552135531355413555135561355713558135591356013561135621356313564135651356613567135681356913570135711357213573135741357513576135771357813579135801358113582135831358413585135861358713588135891359013591135921359313594135951359613597135981359913600136011360213603136041360513606136071360813609136101361113612136131361413615136161361713618136191362013621136221362313624136251362613627136281362913630136311363213633136341363513636136371363813639136401364113642136431364413645136461364713648136491365013651136521365313654136551365613657136581365913660136611366213663136641366513666136671366813669136701367113672136731367413675136761367713678136791368013681136821368313684136851368613687136881368913690136911369213693136941369513696136971369813699137001370113702137031370413705137061370713708137091371013711137121371313714137151371613717137181371913720137211372213723137241372513726137271372813729137301373113732137331373413735137361373713738137391374013741137421374313744137451374613747137481374913750137511375213753137541375513756137571375813759137601376113762137631376413765137661376713768137691377013771137721377313774137751377613777137781377913780137811378213783137841378513786137871378813789137901379113792137931379413795137961379713798137991380013801138021380313804138051380613807138081380913810138111381213813138141381513816138171381813819138201382113822138231382413825138261382713828138291383013831138321383313834138351383613837138381383913840138411384213843138441384513846138471384813849138501385113852138531385413855138561385713858138591386013861138621386313864138651386613867138681386913870138711387213873138741387513876138771387813879138801388113882138831388413885138861388713888138891389013891138921389313894138951389613897138981389913900139011390213903139041390513906139071390813909139101391113912139131391413915139161391713918139191392013921139221392313924139251392613927139281392913930139311393213933139341393513936139371393813939139401394113942139431394413945139461394713948139491395013951139521395313954139551395613957139581395913960139611396213963139641396513966139671396813969139701397113972139731397413975139761397713978139791398013981139821398313984139851398613987139881398913990139911399213993139941399513996139971399813999140001400114002140031400414005140061400714008140091401014011140121401314014140151401614017140181401914020140211402214023140241402514026140271402814029140301403114032140331403414035140361403714038140391404014041140421404314044140451404614047140481404914050140511405214053140541405514056140571405814059140601406114062140631406414065140661406714068140691407014071140721407314074140751407614077140781407914080140811408214083140841408514086140871408814089140901409114092140931409414095140961409714098140991410014101141021410314104141051410614107141081410914110141111411214113141141411514116141171411814119141201412114122141231412414125141261412714128141291413014131141321413314134141351413614137141381413914140141411414214143141441414514146141471414814149141501415114152141531415414155141561415714158141591416014161141621416314164141651416614167141681416914170141711417214173141741417514176141771417814179141801418114182141831418414185141861418714188141891419014191141921419314194141951419614197141981419914200142011420214203142041420514206142071420814209142101421114212142131421414215142161421714218142191422014221142221422314224142251422614227142281422914230142311423214233142341423514236142371423814239142401424114242142431424414245142461424714248142491425014251142521425314254142551425614257142581425914260142611426214263142641426514266142671426814269142701427114272142731427414275142761427714278142791428014281142821428314284142851428614287142881428914290142911429214293142941429514296142971429814299143001430114302143031430414305143061430714308143091431014311143121431314314143151431614317143181431914320143211432214323143241432514326143271432814329143301433114332143331433414335143361433714338143391434014341143421434314344143451434614347143481434914350143511435214353143541435514356143571435814359143601436114362143631436414365143661436714368143691437014371143721437314374143751437614377143781437914380143811438214383143841438514386143871438814389143901439114392143931439414395143961439714398143991440014401144021440314404144051440614407144081440914410144111441214413144141441514416144171441814419144201442114422144231442414425144261442714428144291443014431144321443314434144351443614437144381443914440144411444214443144441444514446144471444814449144501445114452144531445414455144561445714458144591446014461144621446314464144651446614467144681446914470144711447214473144741447514476144771447814479144801448114482144831448414485144861448714488144891449014491144921449314494144951449614497144981449914500145011450214503145041450514506145071450814509145101451114512145131451414515145161451714518145191452014521145221452314524145251452614527145281452914530145311453214533145341453514536145371453814539145401454114542145431454414545145461454714548145491455014551145521455314554145551455614557145581455914560145611456214563145641456514566145671456814569145701457114572145731457414575145761457714578145791458014581145821458314584145851458614587145881458914590145911459214593145941459514596145971459814599146001460114602146031460414605146061460714608146091461014611146121461314614146151461614617146181461914620146211462214623146241462514626146271462814629146301463114632146331463414635146361463714638146391464014641146421464314644146451464614647146481464914650146511465214653146541465514656146571465814659146601466114662146631466414665146661466714668146691467014671146721467314674146751467614677146781467914680146811468214683146841468514686146871468814689146901469114692146931469414695146961469714698146991470014701147021470314704147051470614707147081470914710147111471214713147141471514716147171471814719147201472114722147231472414725147261472714728147291473014731147321473314734147351473614737147381473914740147411474214743147441474514746147471474814749147501475114752147531475414755147561475714758147591476014761147621476314764147651476614767147681476914770147711477214773147741477514776147771477814779147801478114782147831478414785147861478714788147891479014791147921479314794147951479614797147981479914800148011480214803148041480514806148071480814809148101481114812148131481414815148161481714818148191482014821148221482314824148251482614827148281482914830148311483214833148341483514836148371483814839148401484114842148431484414845148461484714848148491485014851148521485314854148551485614857148581485914860148611486214863148641486514866148671486814869148701487114872148731487414875148761487714878148791488014881148821488314884148851488614887148881488914890148911489214893148941489514896148971489814899149001490114902149031490414905149061490714908149091491014911149121491314914149151491614917149181491914920149211492214923149241492514926149271492814929149301493114932149331493414935149361493714938149391494014941149421494314944149451494614947149481494914950149511495214953149541495514956149571495814959149601496114962149631496414965149661496714968149691497014971149721497314974149751497614977149781497914980149811498214983149841498514986149871498814989149901499114992149931499414995149961499714998149991500015001150021500315004150051500615007150081500915010150111501215013150141501515016150171501815019150201502115022150231502415025150261502715028150291503015031150321503315034150351503615037150381503915040150411504215043150441504515046150471504815049150501505115052150531505415055150561505715058150591506015061150621506315064150651506615067150681506915070150711507215073150741507515076150771507815079150801508115082150831508415085150861508715088150891509015091150921509315094150951509615097150981509915100151011510215103151041510515106151071510815109151101511115112151131511415115151161511715118151191512015121151221512315124151251512615127151281512915130151311513215133151341513515136151371513815139151401514115142151431514415145151461514715148151491515015151151521515315154151551515615157151581515915160151611516215163151641516515166151671516815169151701517115172151731517415175151761517715178151791518015181151821518315184151851518615187151881518915190151911519215193151941519515196151971519815199152001520115202152031520415205152061520715208152091521015211152121521315214152151521615217152181521915220152211522215223152241522515226152271522815229152301523115232152331523415235152361523715238152391524015241152421524315244152451524615247152481524915250152511525215253152541525515256152571525815259152601526115262152631526415265152661526715268152691527015271152721527315274152751527615277152781527915280152811528215283152841528515286152871528815289152901529115292152931529415295152961529715298152991530015301153021530315304153051530615307153081530915310153111531215313153141531515316153171531815319153201532115322153231532415325153261532715328153291533015331153321533315334153351533615337153381533915340153411534215343153441534515346153471534815349153501535115352153531535415355153561535715358153591536015361153621536315364153651536615367153681536915370153711537215373153741537515376153771537815379153801538115382153831538415385153861538715388153891539015391153921539315394153951539615397153981539915400154011540215403154041540515406154071540815409154101541115412154131541415415154161541715418154191542015421154221542315424154251542615427154281542915430154311543215433154341543515436154371543815439154401544115442154431544415445154461544715448154491545015451154521545315454154551545615457154581545915460154611546215463154641546515466154671546815469154701547115472154731547415475154761547715478154791548015481154821548315484154851548615487154881548915490154911549215493154941549515496154971549815499155001550115502155031550415505155061550715508155091551015511155121551315514155151551615517155181551915520155211552215523155241552515526155271552815529155301553115532155331553415535155361553715538155391554015541155421554315544155451554615547155481554915550155511555215553155541555515556155571555815559155601556115562155631556415565155661556715568155691557015571155721557315574155751557615577155781557915580155811558215583155841558515586155871558815589155901559115592155931559415595155961559715598155991560015601156021560315604156051560615607156081560915610156111561215613156141561515616156171561815619156201562115622156231562415625156261562715628156291563015631156321563315634156351563615637156381563915640156411564215643156441564515646156471564815649156501565115652156531565415655156561565715658156591566015661156621566315664156651566615667156681566915670156711567215673156741567515676156771567815679156801568115682156831568415685156861568715688156891569015691156921569315694156951569615697156981569915700157011570215703157041570515706157071570815709157101571115712157131571415715157161571715718157191572015721157221572315724157251572615727157281572915730157311573215733157341573515736157371573815739157401574115742157431574415745157461574715748157491575015751157521575315754157551575615757157581575915760157611576215763157641576515766157671576815769157701577115772157731577415775157761577715778157791578015781157821578315784157851578615787157881578915790157911579215793157941579515796157971579815799158001580115802158031580415805158061580715808158091581015811158121581315814158151581615817158181581915820158211582215823158241582515826158271582815829158301583115832158331583415835158361583715838158391584015841158421584315844158451584615847158481584915850158511585215853158541585515856158571585815859158601586115862158631586415865158661586715868158691587015871158721587315874158751587615877158781587915880158811588215883158841588515886158871588815889158901589115892158931589415895158961589715898158991590015901159021590315904159051590615907159081590915910159111591215913159141591515916159171591815919159201592115922159231592415925159261592715928159291593015931159321593315934159351593615937159381593915940159411594215943159441594515946159471594815949159501595115952159531595415955159561595715958159591596015961159621596315964159651596615967159681596915970159711597215973159741597515976159771597815979159801598115982159831598415985159861598715988159891599015991159921599315994159951599615997159981599916000160011600216003160041600516006160071600816009160101601116012160131601416015160161601716018160191602016021160221602316024160251602616027160281602916030160311603216033160341603516036160371603816039160401604116042160431604416045160461604716048160491605016051160521605316054160551605616057160581605916060160611606216063160641606516066160671606816069160701607116072160731607416075160761607716078160791608016081160821608316084160851608616087160881608916090160911609216093160941609516096160971609816099161001610116102161031610416105161061610716108161091611016111161121611316114161151611616117161181611916120161211612216123161241612516126161271612816129161301613116132161331613416135161361613716138161391614016141161421614316144161451614616147161481614916150161511615216153161541615516156161571615816159161601616116162161631616416165161661616716168161691617016171161721617316174161751617616177161781617916180161811618216183161841618516186161871618816189161901619116192161931619416195161961619716198161991620016201162021620316204162051620616207162081620916210162111621216213162141621516216162171621816219162201622116222162231622416225162261622716228162291623016231162321623316234162351623616237162381623916240162411624216243162441624516246162471624816249162501625116252162531625416255162561625716258162591626016261162621626316264162651626616267162681626916270162711627216273162741627516276162771627816279162801628116282162831628416285162861628716288162891629016291162921629316294162951629616297162981629916300163011630216303163041630516306163071630816309163101631116312163131631416315163161631716318163191632016321163221632316324163251632616327163281632916330163311633216333163341633516336163371633816339163401634116342163431634416345163461634716348163491635016351163521635316354163551635616357163581635916360163611636216363163641636516366163671636816369163701637116372163731637416375163761637716378163791638016381163821638316384163851638616387163881638916390163911639216393163941639516396163971639816399164001640116402164031640416405164061640716408164091641016411164121641316414164151641616417164181641916420164211642216423164241642516426164271642816429164301643116432164331643416435164361643716438164391644016441164421644316444164451644616447164481644916450164511645216453164541645516456164571645816459164601646116462164631646416465164661646716468164691647016471164721647316474164751647616477164781647916480164811648216483164841648516486164871648816489164901649116492164931649416495164961649716498164991650016501165021650316504165051650616507165081650916510165111651216513165141651516516165171651816519165201652116522165231652416525165261652716528165291653016531165321653316534165351653616537165381653916540165411654216543165441654516546165471654816549165501655116552165531655416555165561655716558165591656016561165621656316564165651656616567165681656916570165711657216573165741657516576165771657816579165801658116582165831658416585165861658716588165891659016591165921659316594165951659616597165981659916600166011660216603166041660516606166071660816609166101661116612166131661416615166161661716618166191662016621166221662316624166251662616627166281662916630166311663216633166341663516636166371663816639166401664116642166431664416645166461664716648166491665016651166521665316654166551665616657166581665916660166611666216663166641666516666166671666816669166701667116672166731667416675166761667716678166791668016681166821668316684166851668616687166881668916690166911669216693166941669516696166971669816699167001670116702167031670416705167061670716708167091671016711167121671316714167151671616717167181671916720167211672216723167241672516726167271672816729167301673116732167331673416735167361673716738167391674016741167421674316744167451674616747167481674916750167511675216753167541675516756167571675816759167601676116762167631676416765167661676716768167691677016771167721677316774167751677616777167781677916780167811678216783167841678516786167871678816789167901679116792167931679416795167961679716798167991680016801168021680316804168051680616807168081680916810168111681216813168141681516816168171681816819168201682116822168231682416825168261682716828168291683016831168321683316834168351683616837168381683916840168411684216843168441684516846168471684816849168501685116852168531685416855168561685716858168591686016861168621686316864168651686616867168681686916870168711687216873168741687516876168771687816879168801688116882168831688416885168861688716888168891689016891168921689316894168951689616897168981689916900169011690216903169041690516906169071690816909169101691116912169131691416915169161691716918169191692016921169221692316924169251692616927169281692916930169311693216933169341693516936169371693816939169401694116942169431694416945169461694716948169491695016951169521695316954169551695616957169581695916960169611696216963169641696516966169671696816969169701697116972169731697416975169761697716978169791698016981169821698316984169851698616987169881698916990169911699216993169941699516996169971699816999170001700117002170031700417005170061700717008170091701017011170121701317014170151701617017170181701917020170211702217023170241702517026170271702817029170301703117032170331703417035170361703717038170391704017041170421704317044170451704617047170481704917050170511705217053170541705517056170571705817059170601706117062170631706417065170661706717068170691707017071170721707317074170751707617077170781707917080170811708217083170841708517086170871708817089170901709117092170931709417095170961709717098170991710017101171021710317104171051710617107171081710917110171111711217113171141711517116171171711817119171201712117122171231712417125171261712717128171291713017131171321713317134171351713617137171381713917140171411714217143171441714517146171471714817149171501715117152171531715417155171561715717158171591716017161171621716317164171651716617167171681716917170171711717217173171741717517176171771717817179171801718117182171831718417185171861718717188171891719017191171921719317194171951719617197171981719917200172011720217203172041720517206172071720817209172101721117212172131721417215172161721717218172191722017221172221722317224172251722617227172281722917230172311723217233172341723517236172371723817239172401724117242172431724417245172461724717248172491725017251172521725317254172551725617257172581725917260172611726217263172641726517266172671726817269172701727117272172731727417275172761727717278172791728017281172821728317284172851728617287172881728917290172911729217293172941729517296172971729817299173001730117302173031730417305173061730717308173091731017311173121731317314173151731617317173181731917320173211732217323173241732517326173271732817329173301733117332173331733417335173361733717338173391734017341173421734317344173451734617347173481734917350173511735217353173541735517356173571735817359173601736117362173631736417365173661736717368173691737017371173721737317374173751737617377173781737917380173811738217383173841738517386173871738817389173901739117392173931739417395173961739717398173991740017401174021740317404174051740617407174081740917410174111741217413174141741517416174171741817419174201742117422174231742417425174261742717428174291743017431174321743317434174351743617437174381743917440174411744217443174441744517446174471744817449174501745117452174531745417455174561745717458174591746017461174621746317464174651746617467174681746917470174711747217473174741747517476174771747817479174801748117482174831748417485174861748717488174891749017491174921749317494174951749617497174981749917500175011750217503175041750517506175071750817509175101751117512175131751417515175161751717518175191752017521175221752317524175251752617527175281752917530175311753217533175341753517536175371753817539175401754117542175431754417545175461754717548175491755017551175521755317554175551755617557175581755917560175611756217563175641756517566175671756817569175701757117572175731757417575175761757717578175791758017581175821758317584175851758617587175881758917590175911759217593175941759517596175971759817599176001760117602176031760417605176061760717608176091761017611176121761317614176151761617617176181761917620176211762217623176241762517626176271762817629176301763117632176331763417635176361763717638176391764017641176421764317644176451764617647176481764917650176511765217653176541765517656176571765817659176601766117662176631766417665176661766717668176691767017671176721767317674176751767617677176781767917680176811768217683176841768517686176871768817689176901769117692176931769417695176961769717698176991770017701177021770317704177051770617707177081770917710177111771217713177141771517716177171771817719177201772117722177231772417725177261772717728177291773017731177321773317734177351773617737177381773917740177411774217743177441774517746177471774817749177501775117752177531775417755177561775717758177591776017761177621776317764177651776617767177681776917770177711777217773177741777517776177771777817779177801778117782177831778417785177861778717788177891779017791177921779317794177951779617797177981779917800178011780217803178041780517806178071780817809178101781117812178131781417815178161781717818178191782017821178221782317824178251782617827178281782917830178311783217833178341783517836178371783817839178401784117842178431784417845178461784717848178491785017851178521785317854178551785617857178581785917860178611786217863178641786517866178671786817869178701787117872178731787417875178761787717878178791788017881178821788317884178851788617887178881788917890178911789217893178941789517896178971789817899179001790117902179031790417905179061790717908179091791017911179121791317914179151791617917179181791917920179211792217923179241792517926179271792817929179301793117932179331793417935179361793717938179391794017941179421794317944179451794617947179481794917950179511795217953179541795517956179571795817959179601796117962179631796417965179661796717968179691797017971179721797317974179751797617977179781797917980179811798217983179841798517986179871798817989179901799117992179931799417995179961799717998179991800018001180021800318004180051800618007180081800918010180111801218013180141801518016180171801818019180201802118022180231802418025180261802718028180291803018031180321803318034180351803618037180381803918040180411804218043180441804518046180471804818049180501805118052180531805418055180561805718058180591806018061180621806318064180651806618067180681806918070180711807218073180741807518076180771807818079180801808118082180831808418085180861808718088180891809018091180921809318094180951809618097180981809918100181011810218103181041810518106181071810818109181101811118112181131811418115181161811718118181191812018121181221812318124181251812618127181281812918130181311813218133181341813518136181371813818139181401814118142181431814418145181461814718148181491815018151181521815318154181551815618157181581815918160181611816218163181641816518166181671816818169181701817118172181731817418175181761817718178181791818018181181821818318184181851818618187181881818918190181911819218193181941819518196181971819818199182001820118202182031820418205182061820718208182091821018211182121821318214182151821618217182181821918220182211822218223182241822518226182271822818229182301823118232182331823418235182361823718238182391824018241182421824318244182451824618247182481824918250182511825218253182541825518256182571825818259182601826118262182631826418265182661826718268182691827018271182721827318274182751827618277182781827918280182811828218283182841828518286182871828818289182901829118292182931829418295182961829718298182991830018301183021830318304183051830618307183081830918310183111831218313183141831518316183171831818319183201832118322183231832418325183261832718328183291833018331183321833318334183351833618337183381833918340183411834218343183441834518346183471834818349183501835118352183531835418355183561835718358183591836018361183621836318364183651836618367183681836918370183711837218373183741837518376183771837818379183801838118382183831838418385183861838718388183891839018391183921839318394183951839618397183981839918400184011840218403184041840518406184071840818409184101841118412184131841418415184161841718418184191842018421184221842318424184251842618427184281842918430184311843218433184341843518436184371843818439184401844118442184431844418445184461844718448184491845018451184521845318454184551845618457184581845918460184611846218463184641846518466184671846818469184701847118472184731847418475184761847718478184791848018481184821848318484184851848618487184881848918490184911849218493184941849518496184971849818499185001850118502185031850418505185061850718508185091851018511185121851318514185151851618517185181851918520185211852218523185241852518526185271852818529185301853118532185331853418535185361853718538185391854018541185421854318544185451854618547185481854918550185511855218553185541855518556185571855818559185601856118562185631856418565185661856718568185691857018571185721857318574185751857618577185781857918580185811858218583185841858518586185871858818589185901859118592185931859418595185961859718598185991860018601186021860318604186051860618607186081860918610186111861218613186141861518616186171861818619186201862118622186231862418625186261862718628186291863018631186321863318634186351863618637186381863918640186411864218643186441864518646186471864818649186501865118652186531865418655186561865718658186591866018661186621866318664186651866618667186681866918670186711867218673186741867518676186771867818679186801868118682186831868418685186861868718688186891869018691186921869318694186951869618697186981869918700187011870218703187041870518706187071870818709187101871118712187131871418715187161871718718187191872018721187221872318724187251872618727187281872918730187311873218733187341873518736187371873818739187401874118742187431874418745187461874718748187491875018751187521875318754187551875618757187581875918760187611876218763187641876518766187671876818769187701877118772187731877418775187761877718778187791878018781187821878318784187851878618787187881878918790187911879218793187941879518796187971879818799188001880118802188031880418805188061880718808188091881018811188121881318814188151881618817188181881918820188211882218823188241882518826188271882818829188301883118832188331883418835188361883718838188391884018841188421884318844188451884618847188481884918850188511885218853188541885518856188571885818859188601886118862188631886418865188661886718868188691887018871188721887318874188751887618877188781887918880188811888218883188841888518886188871888818889188901889118892188931889418895188961889718898188991890018901189021890318904189051890618907189081890918910189111891218913189141891518916189171891818919189201892118922189231892418925189261892718928189291893018931189321893318934189351893618937189381893918940189411894218943189441894518946189471894818949189501895118952189531895418955189561895718958189591896018961189621896318964189651896618967189681896918970189711897218973189741897518976189771897818979189801898118982189831898418985189861898718988189891899018991189921899318994189951899618997189981899919000190011900219003190041900519006190071900819009190101901119012190131901419015190161901719018190191902019021190221902319024190251902619027190281902919030190311903219033190341903519036190371903819039190401904119042190431904419045190461904719048190491905019051190521905319054190551905619057190581905919060190611906219063190641906519066190671906819069190701907119072190731907419075190761907719078190791908019081190821908319084190851908619087190881908919090190911909219093190941909519096190971909819099191001910119102191031910419105191061910719108191091911019111191121911319114191151911619117191181911919120191211912219123191241912519126191271912819129191301913119132191331913419135191361913719138191391914019141191421914319144191451914619147191481914919150191511915219153191541915519156191571915819159191601916119162191631916419165191661916719168191691917019171191721917319174191751917619177191781917919180191811918219183191841918519186191871918819189191901919119192191931919419195191961919719198191991920019201192021920319204192051920619207192081920919210192111921219213192141921519216192171921819219192201922119222192231922419225192261922719228192291923019231192321923319234192351923619237192381923919240192411924219243192441924519246192471924819249192501925119252192531925419255192561925719258192591926019261192621926319264192651926619267192681926919270192711927219273192741927519276192771927819279192801928119282192831928419285192861928719288192891929019291192921929319294192951929619297192981929919300193011930219303193041930519306193071930819309193101931119312193131931419315193161931719318193191932019321193221932319324193251932619327193281932919330193311933219333193341933519336193371933819339193401934119342193431934419345193461934719348193491935019351193521935319354193551935619357193581935919360193611936219363193641936519366193671936819369193701937119372193731937419375193761937719378193791938019381193821938319384193851938619387193881938919390193911939219393193941939519396193971939819399194001940119402194031940419405194061940719408194091941019411194121941319414194151941619417194181941919420194211942219423194241942519426194271942819429194301943119432194331943419435194361943719438194391944019441194421944319444194451944619447194481944919450194511945219453194541945519456194571945819459194601946119462194631946419465194661946719468194691947019471194721947319474194751947619477194781947919480194811948219483194841948519486194871948819489194901949119492194931949419495194961949719498194991950019501195021950319504195051950619507195081950919510195111951219513195141951519516195171951819519195201952119522195231952419525195261952719528195291953019531195321953319534195351953619537195381953919540195411954219543195441954519546195471954819549195501955119552195531955419555195561955719558195591956019561195621956319564195651956619567195681956919570195711957219573195741957519576195771957819579195801958119582195831958419585195861958719588195891959019591195921959319594195951959619597195981959919600196011960219603196041960519606196071960819609196101961119612196131961419615196161961719618196191962019621196221962319624196251962619627196281962919630196311963219633196341963519636196371963819639196401964119642196431964419645196461964719648196491965019651196521965319654196551965619657196581965919660196611966219663196641966519666196671966819669196701967119672196731967419675196761967719678196791968019681196821968319684196851968619687196881968919690196911969219693196941969519696196971969819699197001970119702197031970419705197061970719708197091971019711197121971319714197151971619717197181971919720197211972219723197241972519726197271972819729197301973119732197331973419735197361973719738197391974019741197421974319744197451974619747197481974919750197511975219753197541975519756197571975819759197601976119762197631976419765197661976719768197691977019771197721977319774197751977619777197781977919780197811978219783197841978519786197871978819789197901979119792197931979419795197961979719798197991980019801198021980319804198051980619807198081980919810198111981219813198141981519816198171981819819198201982119822198231982419825198261982719828198291983019831198321983319834198351983619837198381983919840198411984219843198441984519846198471984819849198501985119852198531985419855198561985719858198591986019861198621986319864198651986619867198681986919870198711987219873198741987519876198771987819879198801988119882198831988419885198861988719888198891989019891198921989319894198951989619897198981989919900199011990219903199041990519906199071990819909199101991119912199131991419915199161991719918199191992019921199221992319924199251992619927199281992919930199311993219933199341993519936199371993819939199401994119942199431994419945199461994719948199491995019951199521995319954199551995619957199581995919960199611996219963199641996519966199671996819969199701997119972199731997419975199761997719978199791998019981199821998319984199851998619987199881998919990199911999219993199941999519996199971999819999200002000120002200032000420005200062000720008200092001020011200122001320014200152001620017200182001920020200212002220023200242002520026200272002820029200302003120032200332003420035200362003720038200392004020041200422004320044200452004620047200482004920050200512005220053200542005520056200572005820059200602006120062200632006420065200662006720068200692007020071200722007320074200752007620077200782007920080200812008220083200842008520086200872008820089200902009120092200932009420095200962009720098200992010020101201022010320104201052010620107201082010920110201112011220113201142011520116201172011820119201202012120122201232012420125201262012720128201292013020131201322013320134201352013620137201382013920140201412014220143201442014520146201472014820149201502015120152201532015420155201562015720158201592016020161201622016320164201652016620167201682016920170201712017220173201742017520176201772017820179201802018120182201832018420185201862018720188201892019020191201922019320194201952019620197201982019920200202012020220203202042020520206202072020820209202102021120212202132021420215202162021720218202192022020221202222022320224202252022620227202282022920230202312023220233202342023520236202372023820239202402024120242202432024420245202462024720248202492025020251202522025320254202552025620257202582025920260202612026220263202642026520266202672026820269202702027120272202732027420275202762027720278202792028020281202822028320284202852028620287202882028920290202912029220293202942029520296202972029820299203002030120302203032030420305203062030720308203092031020311203122031320314203152031620317203182031920320203212032220323203242032520326203272032820329203302033120332203332033420335203362033720338203392034020341203422034320344203452034620347203482034920350203512035220353203542035520356203572035820359203602036120362203632036420365203662036720368203692037020371203722037320374203752037620377203782037920380203812038220383203842038520386203872038820389203902039120392203932039420395203962039720398203992040020401204022040320404204052040620407204082040920410204112041220413204142041520416204172041820419204202042120422204232042420425204262042720428204292043020431204322043320434204352043620437204382043920440204412044220443204442044520446204472044820449204502045120452204532045420455204562045720458204592046020461204622046320464204652046620467204682046920470204712047220473204742047520476204772047820479204802048120482204832048420485204862048720488204892049020491204922049320494204952049620497204982049920500205012050220503205042050520506205072050820509205102051120512205132051420515205162051720518205192052020521205222052320524205252052620527205282052920530205312053220533205342053520536205372053820539205402054120542205432054420545205462054720548205492055020551205522055320554205552055620557205582055920560205612056220563205642056520566205672056820569205702057120572205732057420575205762057720578205792058020581205822058320584205852058620587205882058920590205912059220593205942059520596205972059820599206002060120602206032060420605206062060720608206092061020611206122061320614206152061620617206182061920620206212062220623206242062520626206272062820629206302063120632206332063420635206362063720638206392064020641206422064320644206452064620647206482064920650206512065220653206542065520656206572065820659206602066120662206632066420665206662066720668206692067020671206722067320674206752067620677206782067920680206812068220683206842068520686206872068820689206902069120692206932069420695206962069720698206992070020701207022070320704207052070620707207082070920710207112071220713207142071520716207172071820719207202072120722207232072420725207262072720728207292073020731207322073320734207352073620737207382073920740207412074220743207442074520746207472074820749207502075120752207532075420755207562075720758207592076020761207622076320764207652076620767207682076920770207712077220773207742077520776207772077820779207802078120782207832078420785207862078720788207892079020791207922079320794207952079620797207982079920800208012080220803208042080520806208072080820809208102081120812208132081420815208162081720818208192082020821208222082320824208252082620827208282082920830208312083220833208342083520836208372083820839208402084120842208432084420845208462084720848208492085020851208522085320854208552085620857208582085920860208612086220863208642086520866208672086820869208702087120872208732087420875208762087720878208792088020881208822088320884208852088620887208882088920890208912089220893208942089520896208972089820899209002090120902209032090420905209062090720908209092091020911209122091320914209152091620917209182091920920209212092220923209242092520926209272092820929209302093120932209332093420935209362093720938209392094020941209422094320944209452094620947209482094920950209512095220953209542095520956209572095820959209602096120962209632096420965209662096720968209692097020971209722097320974209752097620977209782097920980209812098220983209842098520986209872098820989209902099120992209932099420995209962099720998209992100021001210022100321004210052100621007210082100921010210112101221013210142101521016210172101821019210202102121022210232102421025210262102721028210292103021031210322103321034210352103621037210382103921040210412104221043210442104521046210472104821049210502105121052210532105421055210562105721058210592106021061210622106321064210652106621067210682106921070210712107221073210742107521076210772107821079210802108121082210832108421085210862108721088210892109021091210922109321094210952109621097210982109921100211012110221103211042110521106211072110821109211102111121112211132111421115211162111721118211192112021121211222112321124211252112621127211282112921130211312113221133211342113521136211372113821139211402114121142211432114421145211462114721148211492115021151211522115321154211552115621157211582115921160211612116221163211642116521166211672116821169211702117121172211732117421175211762117721178211792118021181211822118321184211852118621187211882118921190211912119221193211942119521196211972119821199212002120121202212032120421205212062120721208212092121021211212122121321214212152121621217212182121921220212212122221223212242122521226212272122821229212302123121232212332123421235212362123721238212392124021241212422124321244212452124621247212482124921250212512125221253212542125521256212572125821259212602126121262212632126421265212662126721268212692127021271212722127321274212752127621277212782127921280212812128221283212842128521286212872128821289212902129121292212932129421295212962129721298212992130021301213022130321304213052130621307213082130921310213112131221313213142131521316213172131821319213202132121322213232132421325213262132721328213292133021331213322133321334213352133621337213382133921340213412134221343213442134521346213472134821349213502135121352213532135421355213562135721358213592136021361213622136321364213652136621367213682136921370213712137221373213742137521376213772137821379213802138121382213832138421385213862138721388213892139021391213922139321394213952139621397213982139921400214012140221403214042140521406214072140821409214102141121412214132141421415214162141721418214192142021421214222142321424214252142621427214282142921430214312143221433214342143521436214372143821439214402144121442214432144421445214462144721448214492145021451214522145321454214552145621457214582145921460214612146221463214642146521466214672146821469214702147121472214732147421475214762147721478214792148021481214822148321484214852148621487214882148921490214912149221493214942149521496214972149821499215002150121502215032150421505215062150721508215092151021511215122151321514215152151621517215182151921520215212152221523215242152521526215272152821529215302153121532215332153421535215362153721538215392154021541215422154321544215452154621547215482154921550215512155221553215542155521556215572155821559215602156121562215632156421565215662156721568215692157021571215722157321574215752157621577215782157921580215812158221583215842158521586215872158821589215902159121592215932159421595215962159721598215992160021601216022160321604216052160621607216082160921610216112161221613216142161521616216172161821619216202162121622216232162421625216262162721628216292163021631216322163321634216352163621637216382163921640216412164221643216442164521646216472164821649216502165121652216532165421655216562165721658216592166021661216622166321664216652166621667216682166921670216712167221673216742167521676216772167821679216802168121682216832168421685216862168721688216892169021691216922169321694216952169621697216982169921700217012170221703217042170521706217072170821709217102171121712217132171421715217162171721718217192172021721217222172321724217252172621727217282172921730217312173221733217342173521736217372173821739217402174121742217432174421745217462174721748217492175021751217522175321754217552175621757217582175921760217612176221763217642176521766217672176821769217702177121772217732177421775217762177721778217792178021781217822178321784217852178621787217882178921790217912179221793217942179521796217972179821799218002180121802218032180421805218062180721808218092181021811218122181321814218152181621817218182181921820218212182221823218242182521826218272182821829218302183121832218332183421835218362183721838218392184021841218422184321844218452184621847218482184921850218512185221853218542185521856218572185821859218602186121862218632186421865218662186721868218692187021871218722187321874218752187621877218782187921880218812188221883218842188521886218872188821889218902189121892218932189421895218962189721898218992190021901219022190321904219052190621907219082190921910219112191221913219142191521916219172191821919219202192121922219232192421925219262192721928219292193021931219322193321934219352193621937219382193921940219412194221943219442194521946219472194821949219502195121952219532195421955219562195721958219592196021961219622196321964219652196621967219682196921970219712197221973219742197521976219772197821979219802198121982219832198421985219862198721988219892199021991219922199321994219952199621997219982199922000220012200222003220042200522006220072200822009220102201122012220132201422015220162201722018220192202022021220222202322024220252202622027220282202922030220312203222033220342203522036220372203822039220402204122042220432204422045220462204722048220492205022051220522205322054220552205622057220582205922060220612206222063220642206522066220672206822069220702207122072220732207422075220762207722078220792208022081220822208322084220852208622087220882208922090220912209222093220942209522096220972209822099221002210122102221032210422105221062210722108221092211022111221122211322114221152211622117221182211922120221212212222123221242212522126221272212822129221302213122132221332213422135221362213722138221392214022141221422214322144221452214622147221482214922150221512215222153221542215522156221572215822159221602216122162221632216422165221662216722168221692217022171221722217322174221752217622177221782217922180221812218222183221842218522186221872218822189221902219122192221932219422195221962219722198221992220022201222022220322204222052220622207222082220922210222112221222213222142221522216222172221822219222202222122222222232222422225222262222722228222292223022231222322223322234222352223622237222382223922240222412224222243222442224522246222472224822249222502225122252222532225422255222562225722258222592226022261222622226322264222652226622267222682226922270222712227222273222742227522276222772227822279222802228122282222832228422285222862228722288222892229022291222922229322294222952229622297222982229922300223012230222303223042230522306223072230822309223102231122312223132231422315223162231722318223192232022321223222232322324223252232622327223282232922330223312233222333223342233522336223372233822339223402234122342223432234422345223462234722348223492235022351223522235322354223552235622357223582235922360223612236222363223642236522366223672236822369223702237122372223732237422375223762237722378223792238022381223822238322384223852238622387223882238922390223912239222393223942239522396223972239822399224002240122402224032240422405224062240722408224092241022411224122241322414224152241622417224182241922420224212242222423224242242522426224272242822429224302243122432224332243422435224362243722438224392244022441224422244322444224452244622447224482244922450224512245222453224542245522456224572245822459224602246122462224632246422465224662246722468224692247022471224722247322474224752247622477224782247922480224812248222483224842248522486224872248822489224902249122492224932249422495224962249722498224992250022501225022250322504225052250622507225082250922510225112251222513225142251522516225172251822519225202252122522225232252422525225262252722528225292253022531225322253322534225352253622537225382253922540225412254222543225442254522546225472254822549225502255122552225532255422555225562255722558225592256022561225622256322564225652256622567225682256922570225712257222573225742257522576225772257822579225802258122582225832258422585225862258722588225892259022591225922259322594225952259622597225982259922600226012260222603226042260522606226072260822609226102261122612226132261422615226162261722618226192262022621226222262322624226252262622627226282262922630226312263222633226342263522636226372263822639226402264122642226432264422645226462264722648226492265022651226522265322654226552265622657226582265922660226612266222663226642266522666226672266822669226702267122672226732267422675226762267722678226792268022681226822268322684226852268622687226882268922690226912269222693226942269522696226972269822699227002270122702227032270422705227062270722708227092271022711227122271322714227152271622717227182271922720227212272222723227242272522726227272272822729227302273122732227332273422735227362273722738227392274022741227422274322744227452274622747227482274922750227512275222753227542275522756227572275822759227602276122762227632276422765227662276722768227692277022771227722277322774227752277622777227782277922780227812278222783227842278522786227872278822789227902279122792227932279422795227962279722798227992280022801228022280322804228052280622807228082280922810228112281222813228142281522816228172281822819228202282122822228232282422825228262282722828228292283022831228322283322834228352283622837228382283922840228412284222843228442284522846228472284822849228502285122852228532285422855228562285722858228592286022861228622286322864228652286622867228682286922870228712287222873228742287522876228772287822879228802288122882228832288422885228862288722888228892289022891228922289322894228952289622897228982289922900229012290222903229042290522906229072290822909229102291122912229132291422915229162291722918229192292022921229222292322924229252292622927229282292922930229312293222933229342293522936229372293822939229402294122942229432294422945229462294722948229492295022951229522295322954229552295622957229582295922960229612296222963229642296522966229672296822969229702297122972229732297422975229762297722978229792298022981229822298322984229852298622987229882298922990229912299222993229942299522996229972299822999230002300123002230032300423005230062300723008230092301023011230122301323014230152301623017230182301923020230212302223023230242302523026230272302823029230302303123032230332303423035230362303723038230392304023041230422304323044230452304623047230482304923050230512305223053230542305523056230572305823059230602306123062230632306423065230662306723068230692307023071230722307323074230752307623077230782307923080230812308223083230842308523086230872308823089230902309123092230932309423095230962309723098230992310023101231022310323104231052310623107231082310923110231112311223113231142311523116231172311823119231202312123122231232312423125231262312723128231292313023131231322313323134231352313623137231382313923140231412314223143231442314523146231472314823149231502315123152231532315423155231562315723158231592316023161231622316323164231652316623167231682316923170231712317223173231742317523176231772317823179231802318123182231832318423185231862318723188231892319023191231922319323194231952319623197231982319923200232012320223203232042320523206232072320823209232102321123212232132321423215232162321723218232192322023221232222322323224232252322623227232282322923230232312323223233232342323523236232372323823239232402324123242232432324423245232462324723248232492325023251232522325323254232552325623257232582325923260232612326223263232642326523266232672326823269232702327123272232732327423275232762327723278232792328023281232822328323284232852328623287232882328923290232912329223293232942329523296232972329823299233002330123302233032330423305233062330723308233092331023311233122331323314233152331623317233182331923320233212332223323233242332523326233272332823329233302333123332233332333423335233362333723338233392334023341233422334323344233452334623347233482334923350233512335223353233542335523356233572335823359233602336123362233632336423365233662336723368233692337023371233722337323374233752337623377233782337923380233812338223383233842338523386233872338823389233902339123392233932339423395233962339723398233992340023401234022340323404234052340623407234082340923410234112341223413234142341523416234172341823419234202342123422234232342423425234262342723428234292343023431234322343323434234352343623437234382343923440234412344223443234442344523446234472344823449234502345123452234532345423455234562345723458234592346023461234622346323464234652346623467234682346923470234712347223473234742347523476234772347823479234802348123482234832348423485234862348723488234892349023491234922349323494234952349623497234982349923500235012350223503235042350523506235072350823509235102351123512235132351423515235162351723518235192352023521235222352323524235252352623527235282352923530235312353223533235342353523536235372353823539235402354123542235432354423545235462354723548235492355023551235522355323554235552355623557235582355923560235612356223563235642356523566235672356823569235702357123572235732357423575235762357723578235792358023581235822358323584235852358623587235882358923590235912359223593235942359523596235972359823599236002360123602236032360423605236062360723608236092361023611236122361323614236152361623617236182361923620236212362223623236242362523626236272362823629236302363123632236332363423635236362363723638236392364023641236422364323644236452364623647236482364923650236512365223653236542365523656236572365823659236602366123662236632366423665236662366723668236692367023671236722367323674236752367623677236782367923680236812368223683236842368523686236872368823689236902369123692236932369423695236962369723698236992370023701237022370323704237052370623707237082370923710237112371223713237142371523716237172371823719237202372123722237232372423725237262372723728237292373023731237322373323734237352373623737237382373923740237412374223743237442374523746237472374823749237502375123752237532375423755237562375723758237592376023761237622376323764237652376623767237682376923770237712377223773237742377523776237772377823779237802378123782237832378423785237862378723788237892379023791237922379323794237952379623797237982379923800238012380223803238042380523806238072380823809238102381123812238132381423815238162381723818238192382023821238222382323824238252382623827238282382923830238312383223833238342383523836238372383823839238402384123842238432384423845238462384723848238492385023851238522385323854238552385623857238582385923860238612386223863238642386523866238672386823869238702387123872238732387423875238762387723878238792388023881238822388323884238852388623887238882388923890238912389223893238942389523896238972389823899239002390123902239032390423905239062390723908239092391023911239122391323914239152391623917239182391923920239212392223923239242392523926239272392823929239302393123932239332393423935239362393723938239392394023941239422394323944239452394623947239482394923950239512395223953239542395523956239572395823959239602396123962239632396423965239662396723968239692397023971239722397323974239752397623977239782397923980239812398223983239842398523986 |
- // Code generated by private/model/cli/gen-api/main.go. DO NOT EDIT.
- package wafv2
- import (
- "fmt"
- "time"
- "github.com/aws/aws-sdk-go/aws"
- "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/jsonrpc"
- )
- const opAssociateWebACL = "AssociateWebACL"
- // AssociateWebACLRequest generates a "aws/request.Request" representing the
- // client's request for the AssociateWebACL operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See AssociateWebACL for more information on using the AssociateWebACL
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the AssociateWebACLRequest method.
- // req, resp := client.AssociateWebACLRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/AssociateWebACL
- func (c *WAFV2) AssociateWebACLRequest(input *AssociateWebACLInput) (req *request.Request, output *AssociateWebACLOutput) {
- op := &request.Operation{
- Name: opAssociateWebACL,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &AssociateWebACLInput{}
- }
- output = &AssociateWebACLOutput{}
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Swap(jsonrpc.UnmarshalHandler.Name, protocol.UnmarshalDiscardBodyHandler)
- return
- }
- // AssociateWebACL API operation for AWS WAFV2.
- //
- // Associates a web ACL with a regional application resource, to protect the
- // resource. A regional application can be an Application Load Balancer (ALB),
- // an Amazon API Gateway REST API, an AppSync GraphQL API, or an Amazon Cognito
- // user pool.
- //
- // For Amazon CloudFront, don't use this call. Instead, use your CloudFront
- // distribution configuration. To associate a web ACL, in the CloudFront call
- // UpdateDistribution, set the web ACL ID to the Amazon Resource Name (ARN)
- // of the web ACL. For information, see UpdateDistribution (https://docs.aws.amazon.com/cloudfront/latest/APIReference/API_UpdateDistribution.html).
- //
- // When you make changes to web ACLs or web ACL components, like rules and rule
- // groups, WAF propagates the changes everywhere that the web ACL and its components
- // are stored and used. Your changes are applied within seconds, but there might
- // be a brief period of inconsistency when the changes have arrived in some
- // places and not in others. So, for example, if you change a rule action setting,
- // the action might be the old action in one area and the new action in another
- // area. Or if you add an IP address to an IP set used in a blocking rule, the
- // new address might briefly be blocked in one area while still allowed in another.
- // This temporary inconsistency can occur when you first associate a web ACL
- // with an Amazon Web Services resource and when you change a web ACL that is
- // already associated with a resource. Generally, any inconsistencies of this
- // type last only a few seconds.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation AssociateWebACL for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFNonexistentItemException
- // WAF couldn’t perform the operation because your resource doesn't exist.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate.
- //
- // - WAFUnavailableEntityException
- // WAF couldn’t retrieve a resource that you specified for this operation.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate. Verify the resources that you
- // are specifying in your request parameters and then retry the operation.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/AssociateWebACL
- func (c *WAFV2) AssociateWebACL(input *AssociateWebACLInput) (*AssociateWebACLOutput, error) {
- req, out := c.AssociateWebACLRequest(input)
- return out, req.Send()
- }
- // AssociateWebACLWithContext is the same as AssociateWebACL with the addition of
- // the ability to pass a context and additional request options.
- //
- // See AssociateWebACL for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) AssociateWebACLWithContext(ctx aws.Context, input *AssociateWebACLInput, opts ...request.Option) (*AssociateWebACLOutput, error) {
- req, out := c.AssociateWebACLRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opCheckCapacity = "CheckCapacity"
- // CheckCapacityRequest generates a "aws/request.Request" representing the
- // client's request for the CheckCapacity operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See CheckCapacity for more information on using the CheckCapacity
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the CheckCapacityRequest method.
- // req, resp := client.CheckCapacityRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/CheckCapacity
- func (c *WAFV2) CheckCapacityRequest(input *CheckCapacityInput) (req *request.Request, output *CheckCapacityOutput) {
- op := &request.Operation{
- Name: opCheckCapacity,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &CheckCapacityInput{}
- }
- output = &CheckCapacityOutput{}
- req = c.newRequest(op, input, output)
- return
- }
- // CheckCapacity API operation for AWS WAFV2.
- //
- // Returns the web ACL capacity unit (WCU) requirements for a specified scope
- // and set of rules. You can use this to check the capacity requirements for
- // the rules you want to use in a RuleGroup or WebACL.
- //
- // WAF uses WCUs to calculate and control the operating resources that are used
- // to run your rules, rule groups, and web ACLs. WAF calculates capacity differently
- // for each rule type, to reflect the relative cost of each rule. Simple rules
- // that cost little to run use fewer WCUs than more complex rules that use more
- // processing power. Rule group capacity is fixed at creation, which helps users
- // plan their web ACL WCU usage when they use a rule group. The WCU limit for
- // web ACLs is 1,500.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation CheckCapacity for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFNonexistentItemException
- // WAF couldn’t perform the operation because your resource doesn't exist.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate.
- //
- // - WAFLimitsExceededException
- // WAF couldn’t perform the operation because you exceeded your resource limit.
- // For example, the maximum number of WebACL objects that you can create for
- // an Amazon Web Services account. For more information, see WAF quotas (https://docs.aws.amazon.com/waf/latest/developerguide/limits.html)
- // in the WAF Developer Guide.
- //
- // - WAFInvalidResourceException
- // WAF couldn’t perform the operation because the resource that you requested
- // isn’t valid. Check the resource, and try again.
- //
- // - WAFUnavailableEntityException
- // WAF couldn’t retrieve a resource that you specified for this operation.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate. Verify the resources that you
- // are specifying in your request parameters and then retry the operation.
- //
- // - WAFSubscriptionNotFoundException
- // You tried to use a managed rule group that's available by subscription, but
- // you aren't subscribed to it yet.
- //
- // - WAFExpiredManagedRuleGroupVersionException
- // The operation failed because the specified version for the managed rule group
- // has expired. You can retrieve the available versions for the managed rule
- // group by calling ListAvailableManagedRuleGroupVersions.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/CheckCapacity
- func (c *WAFV2) CheckCapacity(input *CheckCapacityInput) (*CheckCapacityOutput, error) {
- req, out := c.CheckCapacityRequest(input)
- return out, req.Send()
- }
- // CheckCapacityWithContext is the same as CheckCapacity with the addition of
- // the ability to pass a context and additional request options.
- //
- // See CheckCapacity for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) CheckCapacityWithContext(ctx aws.Context, input *CheckCapacityInput, opts ...request.Option) (*CheckCapacityOutput, error) {
- req, out := c.CheckCapacityRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opCreateIPSet = "CreateIPSet"
- // CreateIPSetRequest generates a "aws/request.Request" representing the
- // client's request for the CreateIPSet operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See CreateIPSet for more information on using the CreateIPSet
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the CreateIPSetRequest method.
- // req, resp := client.CreateIPSetRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/CreateIPSet
- func (c *WAFV2) CreateIPSetRequest(input *CreateIPSetInput) (req *request.Request, output *CreateIPSetOutput) {
- op := &request.Operation{
- Name: opCreateIPSet,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &CreateIPSetInput{}
- }
- output = &CreateIPSetOutput{}
- req = c.newRequest(op, input, output)
- return
- }
- // CreateIPSet API operation for AWS WAFV2.
- //
- // Creates an IPSet, which you use to identify web requests that originate from
- // specific IP addresses or ranges of IP addresses. For example, if you're receiving
- // a lot of requests from a ranges of IP addresses, you can configure WAF to
- // block them using an IPSet that lists those IP addresses.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation CreateIPSet for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFDuplicateItemException
- // WAF couldn’t perform the operation because the resource that you tried
- // to save is a duplicate of an existing one.
- //
- // - WAFOptimisticLockException
- // WAF couldn’t save your changes because you tried to update or delete a
- // resource that has changed since you last retrieved it. Get the resource again,
- // make any changes you need to make to the new copy, and retry your operation.
- //
- // - WAFLimitsExceededException
- // WAF couldn’t perform the operation because you exceeded your resource limit.
- // For example, the maximum number of WebACL objects that you can create for
- // an Amazon Web Services account. For more information, see WAF quotas (https://docs.aws.amazon.com/waf/latest/developerguide/limits.html)
- // in the WAF Developer Guide.
- //
- // - WAFTagOperationException
- // An error occurred during the tagging operation. Retry your request.
- //
- // - WAFTagOperationInternalErrorException
- // WAF couldn’t perform your tagging operation because of an internal error.
- // Retry your request.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/CreateIPSet
- func (c *WAFV2) CreateIPSet(input *CreateIPSetInput) (*CreateIPSetOutput, error) {
- req, out := c.CreateIPSetRequest(input)
- return out, req.Send()
- }
- // CreateIPSetWithContext is the same as CreateIPSet with the addition of
- // the ability to pass a context and additional request options.
- //
- // See CreateIPSet for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) CreateIPSetWithContext(ctx aws.Context, input *CreateIPSetInput, opts ...request.Option) (*CreateIPSetOutput, error) {
- req, out := c.CreateIPSetRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opCreateRegexPatternSet = "CreateRegexPatternSet"
- // CreateRegexPatternSetRequest generates a "aws/request.Request" representing the
- // client's request for the CreateRegexPatternSet operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See CreateRegexPatternSet for more information on using the CreateRegexPatternSet
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the CreateRegexPatternSetRequest method.
- // req, resp := client.CreateRegexPatternSetRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/CreateRegexPatternSet
- func (c *WAFV2) CreateRegexPatternSetRequest(input *CreateRegexPatternSetInput) (req *request.Request, output *CreateRegexPatternSetOutput) {
- op := &request.Operation{
- Name: opCreateRegexPatternSet,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &CreateRegexPatternSetInput{}
- }
- output = &CreateRegexPatternSetOutput{}
- req = c.newRequest(op, input, output)
- return
- }
- // CreateRegexPatternSet API operation for AWS WAFV2.
- //
- // Creates a RegexPatternSet, which you reference in a RegexPatternSetReferenceStatement,
- // to have WAF inspect a web request component for the specified patterns.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation CreateRegexPatternSet for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFDuplicateItemException
- // WAF couldn’t perform the operation because the resource that you tried
- // to save is a duplicate of an existing one.
- //
- // - WAFOptimisticLockException
- // WAF couldn’t save your changes because you tried to update or delete a
- // resource that has changed since you last retrieved it. Get the resource again,
- // make any changes you need to make to the new copy, and retry your operation.
- //
- // - WAFLimitsExceededException
- // WAF couldn’t perform the operation because you exceeded your resource limit.
- // For example, the maximum number of WebACL objects that you can create for
- // an Amazon Web Services account. For more information, see WAF quotas (https://docs.aws.amazon.com/waf/latest/developerguide/limits.html)
- // in the WAF Developer Guide.
- //
- // - WAFTagOperationException
- // An error occurred during the tagging operation. Retry your request.
- //
- // - WAFTagOperationInternalErrorException
- // WAF couldn’t perform your tagging operation because of an internal error.
- // Retry your request.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/CreateRegexPatternSet
- func (c *WAFV2) CreateRegexPatternSet(input *CreateRegexPatternSetInput) (*CreateRegexPatternSetOutput, error) {
- req, out := c.CreateRegexPatternSetRequest(input)
- return out, req.Send()
- }
- // CreateRegexPatternSetWithContext is the same as CreateRegexPatternSet with the addition of
- // the ability to pass a context and additional request options.
- //
- // See CreateRegexPatternSet for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) CreateRegexPatternSetWithContext(ctx aws.Context, input *CreateRegexPatternSetInput, opts ...request.Option) (*CreateRegexPatternSetOutput, error) {
- req, out := c.CreateRegexPatternSetRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opCreateRuleGroup = "CreateRuleGroup"
- // CreateRuleGroupRequest generates a "aws/request.Request" representing the
- // client's request for the CreateRuleGroup operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See CreateRuleGroup for more information on using the CreateRuleGroup
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the CreateRuleGroupRequest method.
- // req, resp := client.CreateRuleGroupRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/CreateRuleGroup
- func (c *WAFV2) CreateRuleGroupRequest(input *CreateRuleGroupInput) (req *request.Request, output *CreateRuleGroupOutput) {
- op := &request.Operation{
- Name: opCreateRuleGroup,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &CreateRuleGroupInput{}
- }
- output = &CreateRuleGroupOutput{}
- req = c.newRequest(op, input, output)
- return
- }
- // CreateRuleGroup API operation for AWS WAFV2.
- //
- // Creates a RuleGroup per the specifications provided.
- //
- // A rule group defines a collection of rules to inspect and control web requests
- // that you can use in a WebACL. When you create a rule group, you define an
- // immutable capacity limit. If you update a rule group, you must stay within
- // the capacity. This allows others to reuse the rule group with confidence
- // in its capacity requirements.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation CreateRuleGroup for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFDuplicateItemException
- // WAF couldn’t perform the operation because the resource that you tried
- // to save is a duplicate of an existing one.
- //
- // - WAFOptimisticLockException
- // WAF couldn’t save your changes because you tried to update or delete a
- // resource that has changed since you last retrieved it. Get the resource again,
- // make any changes you need to make to the new copy, and retry your operation.
- //
- // - WAFLimitsExceededException
- // WAF couldn’t perform the operation because you exceeded your resource limit.
- // For example, the maximum number of WebACL objects that you can create for
- // an Amazon Web Services account. For more information, see WAF quotas (https://docs.aws.amazon.com/waf/latest/developerguide/limits.html)
- // in the WAF Developer Guide.
- //
- // - WAFUnavailableEntityException
- // WAF couldn’t retrieve a resource that you specified for this operation.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate. Verify the resources that you
- // are specifying in your request parameters and then retry the operation.
- //
- // - WAFTagOperationException
- // An error occurred during the tagging operation. Retry your request.
- //
- // - WAFTagOperationInternalErrorException
- // WAF couldn’t perform your tagging operation because of an internal error.
- // Retry your request.
- //
- // - WAFSubscriptionNotFoundException
- // You tried to use a managed rule group that's available by subscription, but
- // you aren't subscribed to it yet.
- //
- // - WAFNonexistentItemException
- // WAF couldn’t perform the operation because your resource doesn't exist.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/CreateRuleGroup
- func (c *WAFV2) CreateRuleGroup(input *CreateRuleGroupInput) (*CreateRuleGroupOutput, error) {
- req, out := c.CreateRuleGroupRequest(input)
- return out, req.Send()
- }
- // CreateRuleGroupWithContext is the same as CreateRuleGroup with the addition of
- // the ability to pass a context and additional request options.
- //
- // See CreateRuleGroup for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) CreateRuleGroupWithContext(ctx aws.Context, input *CreateRuleGroupInput, opts ...request.Option) (*CreateRuleGroupOutput, error) {
- req, out := c.CreateRuleGroupRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opCreateWebACL = "CreateWebACL"
- // CreateWebACLRequest generates a "aws/request.Request" representing the
- // client's request for the CreateWebACL operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See CreateWebACL for more information on using the CreateWebACL
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the CreateWebACLRequest method.
- // req, resp := client.CreateWebACLRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/CreateWebACL
- func (c *WAFV2) CreateWebACLRequest(input *CreateWebACLInput) (req *request.Request, output *CreateWebACLOutput) {
- op := &request.Operation{
- Name: opCreateWebACL,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &CreateWebACLInput{}
- }
- output = &CreateWebACLOutput{}
- req = c.newRequest(op, input, output)
- return
- }
- // CreateWebACL API operation for AWS WAFV2.
- //
- // Creates a WebACL per the specifications provided.
- //
- // A web ACL defines a collection of rules to use to inspect and control web
- // requests. Each rule has an action defined (allow, block, or count) for requests
- // that match the statement of the rule. In the web ACL, you assign a default
- // action to take (allow, block) for any request that does not match any of
- // the rules. The rules in a web ACL can be a combination of the types Rule,
- // RuleGroup, and managed rule group. You can associate a web ACL with one or
- // more Amazon Web Services resources to protect. The resources can be an Amazon
- // CloudFront distribution, an Amazon API Gateway REST API, an Application Load
- // Balancer, an AppSync GraphQL API, or an Amazon Cognito user pool.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation CreateWebACL for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFDuplicateItemException
- // WAF couldn’t perform the operation because the resource that you tried
- // to save is a duplicate of an existing one.
- //
- // - WAFOptimisticLockException
- // WAF couldn’t save your changes because you tried to update or delete a
- // resource that has changed since you last retrieved it. Get the resource again,
- // make any changes you need to make to the new copy, and retry your operation.
- //
- // - WAFLimitsExceededException
- // WAF couldn’t perform the operation because you exceeded your resource limit.
- // For example, the maximum number of WebACL objects that you can create for
- // an Amazon Web Services account. For more information, see WAF quotas (https://docs.aws.amazon.com/waf/latest/developerguide/limits.html)
- // in the WAF Developer Guide.
- //
- // - WAFInvalidResourceException
- // WAF couldn’t perform the operation because the resource that you requested
- // isn’t valid. Check the resource, and try again.
- //
- // - WAFUnavailableEntityException
- // WAF couldn’t retrieve a resource that you specified for this operation.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate. Verify the resources that you
- // are specifying in your request parameters and then retry the operation.
- //
- // - WAFNonexistentItemException
- // WAF couldn’t perform the operation because your resource doesn't exist.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate.
- //
- // - WAFTagOperationException
- // An error occurred during the tagging operation. Retry your request.
- //
- // - WAFTagOperationInternalErrorException
- // WAF couldn’t perform your tagging operation because of an internal error.
- // Retry your request.
- //
- // - WAFSubscriptionNotFoundException
- // You tried to use a managed rule group that's available by subscription, but
- // you aren't subscribed to it yet.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // - WAFConfigurationWarningException
- // The operation failed because you are inspecting the web request body, headers,
- // or cookies without specifying how to handle oversize components. Rules that
- // inspect the body must either provide an OversizeHandling configuration or
- // they must be preceded by a SizeConstraintStatement that blocks the body content
- // from being too large. Rules that inspect the headers or cookies must provide
- // an OversizeHandling configuration.
- //
- // Provide the handling configuration and retry your operation.
- //
- // Alternately, you can suppress this warning by adding the following tag to
- // the resource that you provide to this operation: Tag (key:WAF:OversizeFieldsHandlingConstraintOptOut,
- // value:true).
- //
- // - WAFExpiredManagedRuleGroupVersionException
- // The operation failed because the specified version for the managed rule group
- // has expired. You can retrieve the available versions for the managed rule
- // group by calling ListAvailableManagedRuleGroupVersions.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/CreateWebACL
- func (c *WAFV2) CreateWebACL(input *CreateWebACLInput) (*CreateWebACLOutput, error) {
- req, out := c.CreateWebACLRequest(input)
- return out, req.Send()
- }
- // CreateWebACLWithContext is the same as CreateWebACL with the addition of
- // the ability to pass a context and additional request options.
- //
- // See CreateWebACL for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) CreateWebACLWithContext(ctx aws.Context, input *CreateWebACLInput, opts ...request.Option) (*CreateWebACLOutput, error) {
- req, out := c.CreateWebACLRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opDeleteFirewallManagerRuleGroups = "DeleteFirewallManagerRuleGroups"
- // DeleteFirewallManagerRuleGroupsRequest generates a "aws/request.Request" representing the
- // client's request for the DeleteFirewallManagerRuleGroups operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See DeleteFirewallManagerRuleGroups for more information on using the DeleteFirewallManagerRuleGroups
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the DeleteFirewallManagerRuleGroupsRequest method.
- // req, resp := client.DeleteFirewallManagerRuleGroupsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DeleteFirewallManagerRuleGroups
- func (c *WAFV2) DeleteFirewallManagerRuleGroupsRequest(input *DeleteFirewallManagerRuleGroupsInput) (req *request.Request, output *DeleteFirewallManagerRuleGroupsOutput) {
- op := &request.Operation{
- Name: opDeleteFirewallManagerRuleGroups,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DeleteFirewallManagerRuleGroupsInput{}
- }
- output = &DeleteFirewallManagerRuleGroupsOutput{}
- req = c.newRequest(op, input, output)
- return
- }
- // DeleteFirewallManagerRuleGroups API operation for AWS WAFV2.
- //
- // Deletes all rule groups that are managed by Firewall Manager for the specified
- // web ACL.
- //
- // You can only use this if ManagedByFirewallManager is false in the specified
- // WebACL.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation DeleteFirewallManagerRuleGroups for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFNonexistentItemException
- // WAF couldn’t perform the operation because your resource doesn't exist.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate.
- //
- // - WAFOptimisticLockException
- // WAF couldn’t save your changes because you tried to update or delete a
- // resource that has changed since you last retrieved it. Get the resource again,
- // make any changes you need to make to the new copy, and retry your operation.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DeleteFirewallManagerRuleGroups
- func (c *WAFV2) DeleteFirewallManagerRuleGroups(input *DeleteFirewallManagerRuleGroupsInput) (*DeleteFirewallManagerRuleGroupsOutput, error) {
- req, out := c.DeleteFirewallManagerRuleGroupsRequest(input)
- return out, req.Send()
- }
- // DeleteFirewallManagerRuleGroupsWithContext is the same as DeleteFirewallManagerRuleGroups with the addition of
- // the ability to pass a context and additional request options.
- //
- // See DeleteFirewallManagerRuleGroups for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) DeleteFirewallManagerRuleGroupsWithContext(ctx aws.Context, input *DeleteFirewallManagerRuleGroupsInput, opts ...request.Option) (*DeleteFirewallManagerRuleGroupsOutput, error) {
- req, out := c.DeleteFirewallManagerRuleGroupsRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opDeleteIPSet = "DeleteIPSet"
- // DeleteIPSetRequest generates a "aws/request.Request" representing the
- // client's request for the DeleteIPSet operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See DeleteIPSet for more information on using the DeleteIPSet
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the DeleteIPSetRequest method.
- // req, resp := client.DeleteIPSetRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DeleteIPSet
- func (c *WAFV2) DeleteIPSetRequest(input *DeleteIPSetInput) (req *request.Request, output *DeleteIPSetOutput) {
- op := &request.Operation{
- Name: opDeleteIPSet,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DeleteIPSetInput{}
- }
- output = &DeleteIPSetOutput{}
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Swap(jsonrpc.UnmarshalHandler.Name, protocol.UnmarshalDiscardBodyHandler)
- return
- }
- // DeleteIPSet API operation for AWS WAFV2.
- //
- // Deletes the specified IPSet.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation DeleteIPSet for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFNonexistentItemException
- // WAF couldn’t perform the operation because your resource doesn't exist.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate.
- //
- // - WAFOptimisticLockException
- // WAF couldn’t save your changes because you tried to update or delete a
- // resource that has changed since you last retrieved it. Get the resource again,
- // make any changes you need to make to the new copy, and retry your operation.
- //
- // - WAFAssociatedItemException
- // WAF couldn’t perform the operation because your resource is being used
- // by another resource or it’s associated with another resource.
- //
- // - WAFTagOperationException
- // An error occurred during the tagging operation. Retry your request.
- //
- // - WAFTagOperationInternalErrorException
- // WAF couldn’t perform your tagging operation because of an internal error.
- // Retry your request.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DeleteIPSet
- func (c *WAFV2) DeleteIPSet(input *DeleteIPSetInput) (*DeleteIPSetOutput, error) {
- req, out := c.DeleteIPSetRequest(input)
- return out, req.Send()
- }
- // DeleteIPSetWithContext is the same as DeleteIPSet with the addition of
- // the ability to pass a context and additional request options.
- //
- // See DeleteIPSet for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) DeleteIPSetWithContext(ctx aws.Context, input *DeleteIPSetInput, opts ...request.Option) (*DeleteIPSetOutput, error) {
- req, out := c.DeleteIPSetRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opDeleteLoggingConfiguration = "DeleteLoggingConfiguration"
- // DeleteLoggingConfigurationRequest generates a "aws/request.Request" representing the
- // client's request for the DeleteLoggingConfiguration operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See DeleteLoggingConfiguration for more information on using the DeleteLoggingConfiguration
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the DeleteLoggingConfigurationRequest method.
- // req, resp := client.DeleteLoggingConfigurationRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DeleteLoggingConfiguration
- func (c *WAFV2) DeleteLoggingConfigurationRequest(input *DeleteLoggingConfigurationInput) (req *request.Request, output *DeleteLoggingConfigurationOutput) {
- op := &request.Operation{
- Name: opDeleteLoggingConfiguration,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DeleteLoggingConfigurationInput{}
- }
- output = &DeleteLoggingConfigurationOutput{}
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Swap(jsonrpc.UnmarshalHandler.Name, protocol.UnmarshalDiscardBodyHandler)
- return
- }
- // DeleteLoggingConfiguration API operation for AWS WAFV2.
- //
- // Deletes the LoggingConfiguration from the specified web ACL.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation DeleteLoggingConfiguration for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFNonexistentItemException
- // WAF couldn’t perform the operation because your resource doesn't exist.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate.
- //
- // - WAFOptimisticLockException
- // WAF couldn’t save your changes because you tried to update or delete a
- // resource that has changed since you last retrieved it. Get the resource again,
- // make any changes you need to make to the new copy, and retry your operation.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DeleteLoggingConfiguration
- func (c *WAFV2) DeleteLoggingConfiguration(input *DeleteLoggingConfigurationInput) (*DeleteLoggingConfigurationOutput, error) {
- req, out := c.DeleteLoggingConfigurationRequest(input)
- return out, req.Send()
- }
- // DeleteLoggingConfigurationWithContext is the same as DeleteLoggingConfiguration with the addition of
- // the ability to pass a context and additional request options.
- //
- // See DeleteLoggingConfiguration for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) DeleteLoggingConfigurationWithContext(ctx aws.Context, input *DeleteLoggingConfigurationInput, opts ...request.Option) (*DeleteLoggingConfigurationOutput, error) {
- req, out := c.DeleteLoggingConfigurationRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opDeletePermissionPolicy = "DeletePermissionPolicy"
- // DeletePermissionPolicyRequest generates a "aws/request.Request" representing the
- // client's request for the DeletePermissionPolicy operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See DeletePermissionPolicy for more information on using the DeletePermissionPolicy
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the DeletePermissionPolicyRequest method.
- // req, resp := client.DeletePermissionPolicyRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DeletePermissionPolicy
- func (c *WAFV2) DeletePermissionPolicyRequest(input *DeletePermissionPolicyInput) (req *request.Request, output *DeletePermissionPolicyOutput) {
- op := &request.Operation{
- Name: opDeletePermissionPolicy,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DeletePermissionPolicyInput{}
- }
- output = &DeletePermissionPolicyOutput{}
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Swap(jsonrpc.UnmarshalHandler.Name, protocol.UnmarshalDiscardBodyHandler)
- return
- }
- // DeletePermissionPolicy API operation for AWS WAFV2.
- //
- // Permanently deletes an IAM policy from the specified rule group.
- //
- // You must be the owner of the rule group to perform this operation.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation DeletePermissionPolicy for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFNonexistentItemException
- // WAF couldn’t perform the operation because your resource doesn't exist.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate.
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DeletePermissionPolicy
- func (c *WAFV2) DeletePermissionPolicy(input *DeletePermissionPolicyInput) (*DeletePermissionPolicyOutput, error) {
- req, out := c.DeletePermissionPolicyRequest(input)
- return out, req.Send()
- }
- // DeletePermissionPolicyWithContext is the same as DeletePermissionPolicy with the addition of
- // the ability to pass a context and additional request options.
- //
- // See DeletePermissionPolicy for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) DeletePermissionPolicyWithContext(ctx aws.Context, input *DeletePermissionPolicyInput, opts ...request.Option) (*DeletePermissionPolicyOutput, error) {
- req, out := c.DeletePermissionPolicyRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opDeleteRegexPatternSet = "DeleteRegexPatternSet"
- // DeleteRegexPatternSetRequest generates a "aws/request.Request" representing the
- // client's request for the DeleteRegexPatternSet operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See DeleteRegexPatternSet for more information on using the DeleteRegexPatternSet
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the DeleteRegexPatternSetRequest method.
- // req, resp := client.DeleteRegexPatternSetRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DeleteRegexPatternSet
- func (c *WAFV2) DeleteRegexPatternSetRequest(input *DeleteRegexPatternSetInput) (req *request.Request, output *DeleteRegexPatternSetOutput) {
- op := &request.Operation{
- Name: opDeleteRegexPatternSet,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DeleteRegexPatternSetInput{}
- }
- output = &DeleteRegexPatternSetOutput{}
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Swap(jsonrpc.UnmarshalHandler.Name, protocol.UnmarshalDiscardBodyHandler)
- return
- }
- // DeleteRegexPatternSet API operation for AWS WAFV2.
- //
- // Deletes the specified RegexPatternSet.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation DeleteRegexPatternSet for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFNonexistentItemException
- // WAF couldn’t perform the operation because your resource doesn't exist.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate.
- //
- // - WAFOptimisticLockException
- // WAF couldn’t save your changes because you tried to update or delete a
- // resource that has changed since you last retrieved it. Get the resource again,
- // make any changes you need to make to the new copy, and retry your operation.
- //
- // - WAFAssociatedItemException
- // WAF couldn’t perform the operation because your resource is being used
- // by another resource or it’s associated with another resource.
- //
- // - WAFTagOperationException
- // An error occurred during the tagging operation. Retry your request.
- //
- // - WAFTagOperationInternalErrorException
- // WAF couldn’t perform your tagging operation because of an internal error.
- // Retry your request.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DeleteRegexPatternSet
- func (c *WAFV2) DeleteRegexPatternSet(input *DeleteRegexPatternSetInput) (*DeleteRegexPatternSetOutput, error) {
- req, out := c.DeleteRegexPatternSetRequest(input)
- return out, req.Send()
- }
- // DeleteRegexPatternSetWithContext is the same as DeleteRegexPatternSet with the addition of
- // the ability to pass a context and additional request options.
- //
- // See DeleteRegexPatternSet for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) DeleteRegexPatternSetWithContext(ctx aws.Context, input *DeleteRegexPatternSetInput, opts ...request.Option) (*DeleteRegexPatternSetOutput, error) {
- req, out := c.DeleteRegexPatternSetRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opDeleteRuleGroup = "DeleteRuleGroup"
- // DeleteRuleGroupRequest generates a "aws/request.Request" representing the
- // client's request for the DeleteRuleGroup operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See DeleteRuleGroup for more information on using the DeleteRuleGroup
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the DeleteRuleGroupRequest method.
- // req, resp := client.DeleteRuleGroupRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DeleteRuleGroup
- func (c *WAFV2) DeleteRuleGroupRequest(input *DeleteRuleGroupInput) (req *request.Request, output *DeleteRuleGroupOutput) {
- op := &request.Operation{
- Name: opDeleteRuleGroup,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DeleteRuleGroupInput{}
- }
- output = &DeleteRuleGroupOutput{}
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Swap(jsonrpc.UnmarshalHandler.Name, protocol.UnmarshalDiscardBodyHandler)
- return
- }
- // DeleteRuleGroup API operation for AWS WAFV2.
- //
- // Deletes the specified RuleGroup.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation DeleteRuleGroup for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFNonexistentItemException
- // WAF couldn’t perform the operation because your resource doesn't exist.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate.
- //
- // - WAFOptimisticLockException
- // WAF couldn’t save your changes because you tried to update or delete a
- // resource that has changed since you last retrieved it. Get the resource again,
- // make any changes you need to make to the new copy, and retry your operation.
- //
- // - WAFAssociatedItemException
- // WAF couldn’t perform the operation because your resource is being used
- // by another resource or it’s associated with another resource.
- //
- // - WAFTagOperationException
- // An error occurred during the tagging operation. Retry your request.
- //
- // - WAFTagOperationInternalErrorException
- // WAF couldn’t perform your tagging operation because of an internal error.
- // Retry your request.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DeleteRuleGroup
- func (c *WAFV2) DeleteRuleGroup(input *DeleteRuleGroupInput) (*DeleteRuleGroupOutput, error) {
- req, out := c.DeleteRuleGroupRequest(input)
- return out, req.Send()
- }
- // DeleteRuleGroupWithContext is the same as DeleteRuleGroup with the addition of
- // the ability to pass a context and additional request options.
- //
- // See DeleteRuleGroup for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) DeleteRuleGroupWithContext(ctx aws.Context, input *DeleteRuleGroupInput, opts ...request.Option) (*DeleteRuleGroupOutput, error) {
- req, out := c.DeleteRuleGroupRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opDeleteWebACL = "DeleteWebACL"
- // DeleteWebACLRequest generates a "aws/request.Request" representing the
- // client's request for the DeleteWebACL operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See DeleteWebACL for more information on using the DeleteWebACL
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the DeleteWebACLRequest method.
- // req, resp := client.DeleteWebACLRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DeleteWebACL
- func (c *WAFV2) DeleteWebACLRequest(input *DeleteWebACLInput) (req *request.Request, output *DeleteWebACLOutput) {
- op := &request.Operation{
- Name: opDeleteWebACL,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DeleteWebACLInput{}
- }
- output = &DeleteWebACLOutput{}
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Swap(jsonrpc.UnmarshalHandler.Name, protocol.UnmarshalDiscardBodyHandler)
- return
- }
- // DeleteWebACL API operation for AWS WAFV2.
- //
- // Deletes the specified WebACL.
- //
- // You can only use this if ManagedByFirewallManager is false in the specified
- // WebACL.
- //
- // Before deleting any web ACL, first disassociate it from all resources.
- //
- // - To retrieve a list of the resources that are associated with a web ACL,
- // use the following calls: For regional resources, call ListResourcesForWebACL.
- // For Amazon CloudFront distributions, use the CloudFront call ListDistributionsByWebACLId.
- // For information, see ListDistributionsByWebACLId (https://docs.aws.amazon.com/cloudfront/latest/APIReference/API_ListDistributionsByWebACLId.html).
- //
- // - To disassociate a resource from a web ACL, use the following calls:
- // For regional resources, call DisassociateWebACL. For Amazon CloudFront
- // distributions, provide an empty web ACL ID in the CloudFront call UpdateDistribution.
- // For information, see UpdateDistribution (https://docs.aws.amazon.com/cloudfront/latest/APIReference/API_UpdateDistribution.html).
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation DeleteWebACL for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFNonexistentItemException
- // WAF couldn’t perform the operation because your resource doesn't exist.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate.
- //
- // - WAFOptimisticLockException
- // WAF couldn’t save your changes because you tried to update or delete a
- // resource that has changed since you last retrieved it. Get the resource again,
- // make any changes you need to make to the new copy, and retry your operation.
- //
- // - WAFAssociatedItemException
- // WAF couldn’t perform the operation because your resource is being used
- // by another resource or it’s associated with another resource.
- //
- // - WAFTagOperationException
- // An error occurred during the tagging operation. Retry your request.
- //
- // - WAFTagOperationInternalErrorException
- // WAF couldn’t perform your tagging operation because of an internal error.
- // Retry your request.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DeleteWebACL
- func (c *WAFV2) DeleteWebACL(input *DeleteWebACLInput) (*DeleteWebACLOutput, error) {
- req, out := c.DeleteWebACLRequest(input)
- return out, req.Send()
- }
- // DeleteWebACLWithContext is the same as DeleteWebACL with the addition of
- // the ability to pass a context and additional request options.
- //
- // See DeleteWebACL for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) DeleteWebACLWithContext(ctx aws.Context, input *DeleteWebACLInput, opts ...request.Option) (*DeleteWebACLOutput, error) {
- req, out := c.DeleteWebACLRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opDescribeManagedRuleGroup = "DescribeManagedRuleGroup"
- // DescribeManagedRuleGroupRequest generates a "aws/request.Request" representing the
- // client's request for the DescribeManagedRuleGroup operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See DescribeManagedRuleGroup for more information on using the DescribeManagedRuleGroup
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the DescribeManagedRuleGroupRequest method.
- // req, resp := client.DescribeManagedRuleGroupRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DescribeManagedRuleGroup
- func (c *WAFV2) DescribeManagedRuleGroupRequest(input *DescribeManagedRuleGroupInput) (req *request.Request, output *DescribeManagedRuleGroupOutput) {
- op := &request.Operation{
- Name: opDescribeManagedRuleGroup,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DescribeManagedRuleGroupInput{}
- }
- output = &DescribeManagedRuleGroupOutput{}
- req = c.newRequest(op, input, output)
- return
- }
- // DescribeManagedRuleGroup API operation for AWS WAFV2.
- //
- // Provides high-level information for a managed rule group, including descriptions
- // of the rules.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation DescribeManagedRuleGroup for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFInvalidResourceException
- // WAF couldn’t perform the operation because the resource that you requested
- // isn’t valid. Check the resource, and try again.
- //
- // - WAFNonexistentItemException
- // WAF couldn’t perform the operation because your resource doesn't exist.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // - WAFExpiredManagedRuleGroupVersionException
- // The operation failed because the specified version for the managed rule group
- // has expired. You can retrieve the available versions for the managed rule
- // group by calling ListAvailableManagedRuleGroupVersions.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DescribeManagedRuleGroup
- func (c *WAFV2) DescribeManagedRuleGroup(input *DescribeManagedRuleGroupInput) (*DescribeManagedRuleGroupOutput, error) {
- req, out := c.DescribeManagedRuleGroupRequest(input)
- return out, req.Send()
- }
- // DescribeManagedRuleGroupWithContext is the same as DescribeManagedRuleGroup with the addition of
- // the ability to pass a context and additional request options.
- //
- // See DescribeManagedRuleGroup for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) DescribeManagedRuleGroupWithContext(ctx aws.Context, input *DescribeManagedRuleGroupInput, opts ...request.Option) (*DescribeManagedRuleGroupOutput, error) {
- req, out := c.DescribeManagedRuleGroupRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opDisassociateWebACL = "DisassociateWebACL"
- // DisassociateWebACLRequest generates a "aws/request.Request" representing the
- // client's request for the DisassociateWebACL operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See DisassociateWebACL for more information on using the DisassociateWebACL
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the DisassociateWebACLRequest method.
- // req, resp := client.DisassociateWebACLRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DisassociateWebACL
- func (c *WAFV2) DisassociateWebACLRequest(input *DisassociateWebACLInput) (req *request.Request, output *DisassociateWebACLOutput) {
- op := &request.Operation{
- Name: opDisassociateWebACL,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &DisassociateWebACLInput{}
- }
- output = &DisassociateWebACLOutput{}
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Swap(jsonrpc.UnmarshalHandler.Name, protocol.UnmarshalDiscardBodyHandler)
- return
- }
- // DisassociateWebACL API operation for AWS WAFV2.
- //
- // Disassociates the specified regional application resource from any existing
- // web ACL association. A resource can have at most one web ACL association.
- // A regional application can be an Application Load Balancer (ALB), an Amazon
- // API Gateway REST API, an AppSync GraphQL API, or an Amazon Cognito user pool.
- //
- // For Amazon CloudFront, don't use this call. Instead, use your CloudFront
- // distribution configuration. To disassociate a web ACL, provide an empty web
- // ACL ID in the CloudFront call UpdateDistribution. For information, see UpdateDistribution
- // (https://docs.aws.amazon.com/cloudfront/latest/APIReference/API_UpdateDistribution.html).
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation DisassociateWebACL for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFNonexistentItemException
- // WAF couldn’t perform the operation because your resource doesn't exist.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DisassociateWebACL
- func (c *WAFV2) DisassociateWebACL(input *DisassociateWebACLInput) (*DisassociateWebACLOutput, error) {
- req, out := c.DisassociateWebACLRequest(input)
- return out, req.Send()
- }
- // DisassociateWebACLWithContext is the same as DisassociateWebACL with the addition of
- // the ability to pass a context and additional request options.
- //
- // See DisassociateWebACL for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) DisassociateWebACLWithContext(ctx aws.Context, input *DisassociateWebACLInput, opts ...request.Option) (*DisassociateWebACLOutput, error) {
- req, out := c.DisassociateWebACLRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opGenerateMobileSdkReleaseUrl = "GenerateMobileSdkReleaseUrl"
- // GenerateMobileSdkReleaseUrlRequest generates a "aws/request.Request" representing the
- // client's request for the GenerateMobileSdkReleaseUrl operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See GenerateMobileSdkReleaseUrl for more information on using the GenerateMobileSdkReleaseUrl
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the GenerateMobileSdkReleaseUrlRequest method.
- // req, resp := client.GenerateMobileSdkReleaseUrlRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GenerateMobileSdkReleaseUrl
- func (c *WAFV2) GenerateMobileSdkReleaseUrlRequest(input *GenerateMobileSdkReleaseUrlInput) (req *request.Request, output *GenerateMobileSdkReleaseUrlOutput) {
- op := &request.Operation{
- Name: opGenerateMobileSdkReleaseUrl,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &GenerateMobileSdkReleaseUrlInput{}
- }
- output = &GenerateMobileSdkReleaseUrlOutput{}
- req = c.newRequest(op, input, output)
- return
- }
- // GenerateMobileSdkReleaseUrl API operation for AWS WAFV2.
- //
- // Generates a presigned download URL for the specified release of the mobile
- // SDK.
- //
- // The mobile SDK is not generally available. Customers who have access to the
- // mobile SDK can use it to establish and manage WAF tokens for use in HTTP(S)
- // requests from a mobile device to WAF. For more information, see WAF client
- // application integration (https://docs.aws.amazon.com/waf/latest/developerguide/waf-application-integration.html)
- // in the WAF Developer Guide.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation GenerateMobileSdkReleaseUrl for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFNonexistentItemException
- // WAF couldn’t perform the operation because your resource doesn't exist.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GenerateMobileSdkReleaseUrl
- func (c *WAFV2) GenerateMobileSdkReleaseUrl(input *GenerateMobileSdkReleaseUrlInput) (*GenerateMobileSdkReleaseUrlOutput, error) {
- req, out := c.GenerateMobileSdkReleaseUrlRequest(input)
- return out, req.Send()
- }
- // GenerateMobileSdkReleaseUrlWithContext is the same as GenerateMobileSdkReleaseUrl with the addition of
- // the ability to pass a context and additional request options.
- //
- // See GenerateMobileSdkReleaseUrl for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) GenerateMobileSdkReleaseUrlWithContext(ctx aws.Context, input *GenerateMobileSdkReleaseUrlInput, opts ...request.Option) (*GenerateMobileSdkReleaseUrlOutput, error) {
- req, out := c.GenerateMobileSdkReleaseUrlRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opGetIPSet = "GetIPSet"
- // GetIPSetRequest generates a "aws/request.Request" representing the
- // client's request for the GetIPSet operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See GetIPSet for more information on using the GetIPSet
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the GetIPSetRequest method.
- // req, resp := client.GetIPSetRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetIPSet
- func (c *WAFV2) GetIPSetRequest(input *GetIPSetInput) (req *request.Request, output *GetIPSetOutput) {
- op := &request.Operation{
- Name: opGetIPSet,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &GetIPSetInput{}
- }
- output = &GetIPSetOutput{}
- req = c.newRequest(op, input, output)
- return
- }
- // GetIPSet API operation for AWS WAFV2.
- //
- // Retrieves the specified IPSet.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation GetIPSet for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFNonexistentItemException
- // WAF couldn’t perform the operation because your resource doesn't exist.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetIPSet
- func (c *WAFV2) GetIPSet(input *GetIPSetInput) (*GetIPSetOutput, error) {
- req, out := c.GetIPSetRequest(input)
- return out, req.Send()
- }
- // GetIPSetWithContext is the same as GetIPSet with the addition of
- // the ability to pass a context and additional request options.
- //
- // See GetIPSet for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) GetIPSetWithContext(ctx aws.Context, input *GetIPSetInput, opts ...request.Option) (*GetIPSetOutput, error) {
- req, out := c.GetIPSetRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opGetLoggingConfiguration = "GetLoggingConfiguration"
- // GetLoggingConfigurationRequest generates a "aws/request.Request" representing the
- // client's request for the GetLoggingConfiguration operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See GetLoggingConfiguration for more information on using the GetLoggingConfiguration
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the GetLoggingConfigurationRequest method.
- // req, resp := client.GetLoggingConfigurationRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetLoggingConfiguration
- func (c *WAFV2) GetLoggingConfigurationRequest(input *GetLoggingConfigurationInput) (req *request.Request, output *GetLoggingConfigurationOutput) {
- op := &request.Operation{
- Name: opGetLoggingConfiguration,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &GetLoggingConfigurationInput{}
- }
- output = &GetLoggingConfigurationOutput{}
- req = c.newRequest(op, input, output)
- return
- }
- // GetLoggingConfiguration API operation for AWS WAFV2.
- //
- // Returns the LoggingConfiguration for the specified web ACL.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation GetLoggingConfiguration for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFNonexistentItemException
- // WAF couldn’t perform the operation because your resource doesn't exist.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetLoggingConfiguration
- func (c *WAFV2) GetLoggingConfiguration(input *GetLoggingConfigurationInput) (*GetLoggingConfigurationOutput, error) {
- req, out := c.GetLoggingConfigurationRequest(input)
- return out, req.Send()
- }
- // GetLoggingConfigurationWithContext is the same as GetLoggingConfiguration with the addition of
- // the ability to pass a context and additional request options.
- //
- // See GetLoggingConfiguration for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) GetLoggingConfigurationWithContext(ctx aws.Context, input *GetLoggingConfigurationInput, opts ...request.Option) (*GetLoggingConfigurationOutput, error) {
- req, out := c.GetLoggingConfigurationRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opGetManagedRuleSet = "GetManagedRuleSet"
- // GetManagedRuleSetRequest generates a "aws/request.Request" representing the
- // client's request for the GetManagedRuleSet operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See GetManagedRuleSet for more information on using the GetManagedRuleSet
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the GetManagedRuleSetRequest method.
- // req, resp := client.GetManagedRuleSetRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetManagedRuleSet
- func (c *WAFV2) GetManagedRuleSetRequest(input *GetManagedRuleSetInput) (req *request.Request, output *GetManagedRuleSetOutput) {
- op := &request.Operation{
- Name: opGetManagedRuleSet,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &GetManagedRuleSetInput{}
- }
- output = &GetManagedRuleSetOutput{}
- req = c.newRequest(op, input, output)
- return
- }
- // GetManagedRuleSet API operation for AWS WAFV2.
- //
- // Retrieves the specified managed rule set.
- //
- // This is intended for use only by vendors of managed rule sets. Vendors are
- // Amazon Web Services and Amazon Web Services Marketplace sellers.
- //
- // Vendors, you can use the managed rule set APIs to provide controlled rollout
- // of your versioned managed rule group offerings for your customers. The APIs
- // are ListManagedRuleSets, GetManagedRuleSet, PutManagedRuleSetVersions, and
- // UpdateManagedRuleSetVersionExpiryDate.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation GetManagedRuleSet for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFNonexistentItemException
- // WAF couldn’t perform the operation because your resource doesn't exist.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetManagedRuleSet
- func (c *WAFV2) GetManagedRuleSet(input *GetManagedRuleSetInput) (*GetManagedRuleSetOutput, error) {
- req, out := c.GetManagedRuleSetRequest(input)
- return out, req.Send()
- }
- // GetManagedRuleSetWithContext is the same as GetManagedRuleSet with the addition of
- // the ability to pass a context and additional request options.
- //
- // See GetManagedRuleSet for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) GetManagedRuleSetWithContext(ctx aws.Context, input *GetManagedRuleSetInput, opts ...request.Option) (*GetManagedRuleSetOutput, error) {
- req, out := c.GetManagedRuleSetRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opGetMobileSdkRelease = "GetMobileSdkRelease"
- // GetMobileSdkReleaseRequest generates a "aws/request.Request" representing the
- // client's request for the GetMobileSdkRelease operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See GetMobileSdkRelease for more information on using the GetMobileSdkRelease
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the GetMobileSdkReleaseRequest method.
- // req, resp := client.GetMobileSdkReleaseRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetMobileSdkRelease
- func (c *WAFV2) GetMobileSdkReleaseRequest(input *GetMobileSdkReleaseInput) (req *request.Request, output *GetMobileSdkReleaseOutput) {
- op := &request.Operation{
- Name: opGetMobileSdkRelease,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &GetMobileSdkReleaseInput{}
- }
- output = &GetMobileSdkReleaseOutput{}
- req = c.newRequest(op, input, output)
- return
- }
- // GetMobileSdkRelease API operation for AWS WAFV2.
- //
- // Retrieves information for the specified mobile SDK release, including release
- // notes and tags.
- //
- // The mobile SDK is not generally available. Customers who have access to the
- // mobile SDK can use it to establish and manage WAF tokens for use in HTTP(S)
- // requests from a mobile device to WAF. For more information, see WAF client
- // application integration (https://docs.aws.amazon.com/waf/latest/developerguide/waf-application-integration.html)
- // in the WAF Developer Guide.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation GetMobileSdkRelease for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFNonexistentItemException
- // WAF couldn’t perform the operation because your resource doesn't exist.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetMobileSdkRelease
- func (c *WAFV2) GetMobileSdkRelease(input *GetMobileSdkReleaseInput) (*GetMobileSdkReleaseOutput, error) {
- req, out := c.GetMobileSdkReleaseRequest(input)
- return out, req.Send()
- }
- // GetMobileSdkReleaseWithContext is the same as GetMobileSdkRelease with the addition of
- // the ability to pass a context and additional request options.
- //
- // See GetMobileSdkRelease for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) GetMobileSdkReleaseWithContext(ctx aws.Context, input *GetMobileSdkReleaseInput, opts ...request.Option) (*GetMobileSdkReleaseOutput, error) {
- req, out := c.GetMobileSdkReleaseRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opGetPermissionPolicy = "GetPermissionPolicy"
- // GetPermissionPolicyRequest generates a "aws/request.Request" representing the
- // client's request for the GetPermissionPolicy operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See GetPermissionPolicy for more information on using the GetPermissionPolicy
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the GetPermissionPolicyRequest method.
- // req, resp := client.GetPermissionPolicyRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetPermissionPolicy
- func (c *WAFV2) GetPermissionPolicyRequest(input *GetPermissionPolicyInput) (req *request.Request, output *GetPermissionPolicyOutput) {
- op := &request.Operation{
- Name: opGetPermissionPolicy,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &GetPermissionPolicyInput{}
- }
- output = &GetPermissionPolicyOutput{}
- req = c.newRequest(op, input, output)
- return
- }
- // GetPermissionPolicy API operation for AWS WAFV2.
- //
- // Returns the IAM policy that is attached to the specified rule group.
- //
- // You must be the owner of the rule group to perform this operation.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation GetPermissionPolicy for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFNonexistentItemException
- // WAF couldn’t perform the operation because your resource doesn't exist.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate.
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetPermissionPolicy
- func (c *WAFV2) GetPermissionPolicy(input *GetPermissionPolicyInput) (*GetPermissionPolicyOutput, error) {
- req, out := c.GetPermissionPolicyRequest(input)
- return out, req.Send()
- }
- // GetPermissionPolicyWithContext is the same as GetPermissionPolicy with the addition of
- // the ability to pass a context and additional request options.
- //
- // See GetPermissionPolicy for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) GetPermissionPolicyWithContext(ctx aws.Context, input *GetPermissionPolicyInput, opts ...request.Option) (*GetPermissionPolicyOutput, error) {
- req, out := c.GetPermissionPolicyRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opGetRateBasedStatementManagedKeys = "GetRateBasedStatementManagedKeys"
- // GetRateBasedStatementManagedKeysRequest generates a "aws/request.Request" representing the
- // client's request for the GetRateBasedStatementManagedKeys operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See GetRateBasedStatementManagedKeys for more information on using the GetRateBasedStatementManagedKeys
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the GetRateBasedStatementManagedKeysRequest method.
- // req, resp := client.GetRateBasedStatementManagedKeysRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetRateBasedStatementManagedKeys
- func (c *WAFV2) GetRateBasedStatementManagedKeysRequest(input *GetRateBasedStatementManagedKeysInput) (req *request.Request, output *GetRateBasedStatementManagedKeysOutput) {
- op := &request.Operation{
- Name: opGetRateBasedStatementManagedKeys,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &GetRateBasedStatementManagedKeysInput{}
- }
- output = &GetRateBasedStatementManagedKeysOutput{}
- req = c.newRequest(op, input, output)
- return
- }
- // GetRateBasedStatementManagedKeys API operation for AWS WAFV2.
- //
- // Retrieves the keys that are currently blocked by a rate-based rule instance.
- // The maximum number of managed keys that can be blocked for a single rate-based
- // rule instance is 10,000. If more than 10,000 addresses exceed the rate limit,
- // those with the highest rates are blocked.
- //
- // For a rate-based rule that you've defined inside a rule group, provide the
- // name of the rule group reference statement in your request, in addition to
- // the rate-based rule name and the web ACL name.
- //
- // WAF monitors web requests and manages keys independently for each unique
- // combination of web ACL, optional rule group, and rate-based rule. For example,
- // if you define a rate-based rule inside a rule group, and then use the rule
- // group in a web ACL, WAF monitors web requests and manages keys for that web
- // ACL, rule group reference statement, and rate-based rule instance. If you
- // use the same rule group in a second web ACL, WAF monitors web requests and
- // manages keys for this second usage completely independent of your first.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation GetRateBasedStatementManagedKeys for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFNonexistentItemException
- // WAF couldn’t perform the operation because your resource doesn't exist.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetRateBasedStatementManagedKeys
- func (c *WAFV2) GetRateBasedStatementManagedKeys(input *GetRateBasedStatementManagedKeysInput) (*GetRateBasedStatementManagedKeysOutput, error) {
- req, out := c.GetRateBasedStatementManagedKeysRequest(input)
- return out, req.Send()
- }
- // GetRateBasedStatementManagedKeysWithContext is the same as GetRateBasedStatementManagedKeys with the addition of
- // the ability to pass a context and additional request options.
- //
- // See GetRateBasedStatementManagedKeys for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) GetRateBasedStatementManagedKeysWithContext(ctx aws.Context, input *GetRateBasedStatementManagedKeysInput, opts ...request.Option) (*GetRateBasedStatementManagedKeysOutput, error) {
- req, out := c.GetRateBasedStatementManagedKeysRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opGetRegexPatternSet = "GetRegexPatternSet"
- // GetRegexPatternSetRequest generates a "aws/request.Request" representing the
- // client's request for the GetRegexPatternSet operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See GetRegexPatternSet for more information on using the GetRegexPatternSet
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the GetRegexPatternSetRequest method.
- // req, resp := client.GetRegexPatternSetRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetRegexPatternSet
- func (c *WAFV2) GetRegexPatternSetRequest(input *GetRegexPatternSetInput) (req *request.Request, output *GetRegexPatternSetOutput) {
- op := &request.Operation{
- Name: opGetRegexPatternSet,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &GetRegexPatternSetInput{}
- }
- output = &GetRegexPatternSetOutput{}
- req = c.newRequest(op, input, output)
- return
- }
- // GetRegexPatternSet API operation for AWS WAFV2.
- //
- // Retrieves the specified RegexPatternSet.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation GetRegexPatternSet for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFNonexistentItemException
- // WAF couldn’t perform the operation because your resource doesn't exist.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetRegexPatternSet
- func (c *WAFV2) GetRegexPatternSet(input *GetRegexPatternSetInput) (*GetRegexPatternSetOutput, error) {
- req, out := c.GetRegexPatternSetRequest(input)
- return out, req.Send()
- }
- // GetRegexPatternSetWithContext is the same as GetRegexPatternSet with the addition of
- // the ability to pass a context and additional request options.
- //
- // See GetRegexPatternSet for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) GetRegexPatternSetWithContext(ctx aws.Context, input *GetRegexPatternSetInput, opts ...request.Option) (*GetRegexPatternSetOutput, error) {
- req, out := c.GetRegexPatternSetRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opGetRuleGroup = "GetRuleGroup"
- // GetRuleGroupRequest generates a "aws/request.Request" representing the
- // client's request for the GetRuleGroup operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See GetRuleGroup for more information on using the GetRuleGroup
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the GetRuleGroupRequest method.
- // req, resp := client.GetRuleGroupRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetRuleGroup
- func (c *WAFV2) GetRuleGroupRequest(input *GetRuleGroupInput) (req *request.Request, output *GetRuleGroupOutput) {
- op := &request.Operation{
- Name: opGetRuleGroup,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &GetRuleGroupInput{}
- }
- output = &GetRuleGroupOutput{}
- req = c.newRequest(op, input, output)
- return
- }
- // GetRuleGroup API operation for AWS WAFV2.
- //
- // Retrieves the specified RuleGroup.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation GetRuleGroup for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFNonexistentItemException
- // WAF couldn’t perform the operation because your resource doesn't exist.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetRuleGroup
- func (c *WAFV2) GetRuleGroup(input *GetRuleGroupInput) (*GetRuleGroupOutput, error) {
- req, out := c.GetRuleGroupRequest(input)
- return out, req.Send()
- }
- // GetRuleGroupWithContext is the same as GetRuleGroup with the addition of
- // the ability to pass a context and additional request options.
- //
- // See GetRuleGroup for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) GetRuleGroupWithContext(ctx aws.Context, input *GetRuleGroupInput, opts ...request.Option) (*GetRuleGroupOutput, error) {
- req, out := c.GetRuleGroupRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opGetSampledRequests = "GetSampledRequests"
- // GetSampledRequestsRequest generates a "aws/request.Request" representing the
- // client's request for the GetSampledRequests operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See GetSampledRequests for more information on using the GetSampledRequests
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the GetSampledRequestsRequest method.
- // req, resp := client.GetSampledRequestsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetSampledRequests
- func (c *WAFV2) GetSampledRequestsRequest(input *GetSampledRequestsInput) (req *request.Request, output *GetSampledRequestsOutput) {
- op := &request.Operation{
- Name: opGetSampledRequests,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &GetSampledRequestsInput{}
- }
- output = &GetSampledRequestsOutput{}
- req = c.newRequest(op, input, output)
- return
- }
- // GetSampledRequests API operation for AWS WAFV2.
- //
- // Gets detailed information about a specified number of requests--a sample--that
- // WAF randomly selects from among the first 5,000 requests that your Amazon
- // Web Services resource received during a time range that you choose. You can
- // specify a sample size of up to 500 requests, and you can specify any time
- // range in the previous three hours.
- //
- // GetSampledRequests returns a time range, which is usually the time range
- // that you specified. However, if your resource (such as a CloudFront distribution)
- // received 5,000 requests before the specified time range elapsed, GetSampledRequests
- // returns an updated time range. This new time range indicates the actual period
- // during which WAF selected the requests in the sample.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation GetSampledRequests for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFNonexistentItemException
- // WAF couldn’t perform the operation because your resource doesn't exist.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate.
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetSampledRequests
- func (c *WAFV2) GetSampledRequests(input *GetSampledRequestsInput) (*GetSampledRequestsOutput, error) {
- req, out := c.GetSampledRequestsRequest(input)
- return out, req.Send()
- }
- // GetSampledRequestsWithContext is the same as GetSampledRequests with the addition of
- // the ability to pass a context and additional request options.
- //
- // See GetSampledRequests for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) GetSampledRequestsWithContext(ctx aws.Context, input *GetSampledRequestsInput, opts ...request.Option) (*GetSampledRequestsOutput, error) {
- req, out := c.GetSampledRequestsRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opGetWebACL = "GetWebACL"
- // GetWebACLRequest generates a "aws/request.Request" representing the
- // client's request for the GetWebACL operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See GetWebACL for more information on using the GetWebACL
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the GetWebACLRequest method.
- // req, resp := client.GetWebACLRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetWebACL
- func (c *WAFV2) GetWebACLRequest(input *GetWebACLInput) (req *request.Request, output *GetWebACLOutput) {
- op := &request.Operation{
- Name: opGetWebACL,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &GetWebACLInput{}
- }
- output = &GetWebACLOutput{}
- req = c.newRequest(op, input, output)
- return
- }
- // GetWebACL API operation for AWS WAFV2.
- //
- // Retrieves the specified WebACL.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation GetWebACL for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFNonexistentItemException
- // WAF couldn’t perform the operation because your resource doesn't exist.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetWebACL
- func (c *WAFV2) GetWebACL(input *GetWebACLInput) (*GetWebACLOutput, error) {
- req, out := c.GetWebACLRequest(input)
- return out, req.Send()
- }
- // GetWebACLWithContext is the same as GetWebACL with the addition of
- // the ability to pass a context and additional request options.
- //
- // See GetWebACL for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) GetWebACLWithContext(ctx aws.Context, input *GetWebACLInput, opts ...request.Option) (*GetWebACLOutput, error) {
- req, out := c.GetWebACLRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opGetWebACLForResource = "GetWebACLForResource"
- // GetWebACLForResourceRequest generates a "aws/request.Request" representing the
- // client's request for the GetWebACLForResource operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See GetWebACLForResource for more information on using the GetWebACLForResource
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the GetWebACLForResourceRequest method.
- // req, resp := client.GetWebACLForResourceRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetWebACLForResource
- func (c *WAFV2) GetWebACLForResourceRequest(input *GetWebACLForResourceInput) (req *request.Request, output *GetWebACLForResourceOutput) {
- op := &request.Operation{
- Name: opGetWebACLForResource,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &GetWebACLForResourceInput{}
- }
- output = &GetWebACLForResourceOutput{}
- req = c.newRequest(op, input, output)
- return
- }
- // GetWebACLForResource API operation for AWS WAFV2.
- //
- // Retrieves the WebACL for the specified resource.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation GetWebACLForResource for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFNonexistentItemException
- // WAF couldn’t perform the operation because your resource doesn't exist.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFUnavailableEntityException
- // WAF couldn’t retrieve a resource that you specified for this operation.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate. Verify the resources that you
- // are specifying in your request parameters and then retry the operation.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetWebACLForResource
- func (c *WAFV2) GetWebACLForResource(input *GetWebACLForResourceInput) (*GetWebACLForResourceOutput, error) {
- req, out := c.GetWebACLForResourceRequest(input)
- return out, req.Send()
- }
- // GetWebACLForResourceWithContext is the same as GetWebACLForResource with the addition of
- // the ability to pass a context and additional request options.
- //
- // See GetWebACLForResource for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) GetWebACLForResourceWithContext(ctx aws.Context, input *GetWebACLForResourceInput, opts ...request.Option) (*GetWebACLForResourceOutput, error) {
- req, out := c.GetWebACLForResourceRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opListAvailableManagedRuleGroupVersions = "ListAvailableManagedRuleGroupVersions"
- // ListAvailableManagedRuleGroupVersionsRequest generates a "aws/request.Request" representing the
- // client's request for the ListAvailableManagedRuleGroupVersions operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See ListAvailableManagedRuleGroupVersions for more information on using the ListAvailableManagedRuleGroupVersions
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the ListAvailableManagedRuleGroupVersionsRequest method.
- // req, resp := client.ListAvailableManagedRuleGroupVersionsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListAvailableManagedRuleGroupVersions
- func (c *WAFV2) ListAvailableManagedRuleGroupVersionsRequest(input *ListAvailableManagedRuleGroupVersionsInput) (req *request.Request, output *ListAvailableManagedRuleGroupVersionsOutput) {
- op := &request.Operation{
- Name: opListAvailableManagedRuleGroupVersions,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ListAvailableManagedRuleGroupVersionsInput{}
- }
- output = &ListAvailableManagedRuleGroupVersionsOutput{}
- req = c.newRequest(op, input, output)
- return
- }
- // ListAvailableManagedRuleGroupVersions API operation for AWS WAFV2.
- //
- // Returns a list of the available versions for the specified managed rule group.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation ListAvailableManagedRuleGroupVersions for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFNonexistentItemException
- // WAF couldn’t perform the operation because your resource doesn't exist.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListAvailableManagedRuleGroupVersions
- func (c *WAFV2) ListAvailableManagedRuleGroupVersions(input *ListAvailableManagedRuleGroupVersionsInput) (*ListAvailableManagedRuleGroupVersionsOutput, error) {
- req, out := c.ListAvailableManagedRuleGroupVersionsRequest(input)
- return out, req.Send()
- }
- // ListAvailableManagedRuleGroupVersionsWithContext is the same as ListAvailableManagedRuleGroupVersions with the addition of
- // the ability to pass a context and additional request options.
- //
- // See ListAvailableManagedRuleGroupVersions for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) ListAvailableManagedRuleGroupVersionsWithContext(ctx aws.Context, input *ListAvailableManagedRuleGroupVersionsInput, opts ...request.Option) (*ListAvailableManagedRuleGroupVersionsOutput, error) {
- req, out := c.ListAvailableManagedRuleGroupVersionsRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opListAvailableManagedRuleGroups = "ListAvailableManagedRuleGroups"
- // ListAvailableManagedRuleGroupsRequest generates a "aws/request.Request" representing the
- // client's request for the ListAvailableManagedRuleGroups operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See ListAvailableManagedRuleGroups for more information on using the ListAvailableManagedRuleGroups
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the ListAvailableManagedRuleGroupsRequest method.
- // req, resp := client.ListAvailableManagedRuleGroupsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListAvailableManagedRuleGroups
- func (c *WAFV2) ListAvailableManagedRuleGroupsRequest(input *ListAvailableManagedRuleGroupsInput) (req *request.Request, output *ListAvailableManagedRuleGroupsOutput) {
- op := &request.Operation{
- Name: opListAvailableManagedRuleGroups,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ListAvailableManagedRuleGroupsInput{}
- }
- output = &ListAvailableManagedRuleGroupsOutput{}
- req = c.newRequest(op, input, output)
- return
- }
- // ListAvailableManagedRuleGroups API operation for AWS WAFV2.
- //
- // Retrieves an array of managed rule groups that are available for you to use.
- // This list includes all Amazon Web Services Managed Rules rule groups and
- // all of the Amazon Web Services Marketplace managed rule groups that you're
- // subscribed to.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation ListAvailableManagedRuleGroups for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListAvailableManagedRuleGroups
- func (c *WAFV2) ListAvailableManagedRuleGroups(input *ListAvailableManagedRuleGroupsInput) (*ListAvailableManagedRuleGroupsOutput, error) {
- req, out := c.ListAvailableManagedRuleGroupsRequest(input)
- return out, req.Send()
- }
- // ListAvailableManagedRuleGroupsWithContext is the same as ListAvailableManagedRuleGroups with the addition of
- // the ability to pass a context and additional request options.
- //
- // See ListAvailableManagedRuleGroups for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) ListAvailableManagedRuleGroupsWithContext(ctx aws.Context, input *ListAvailableManagedRuleGroupsInput, opts ...request.Option) (*ListAvailableManagedRuleGroupsOutput, error) {
- req, out := c.ListAvailableManagedRuleGroupsRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opListIPSets = "ListIPSets"
- // ListIPSetsRequest generates a "aws/request.Request" representing the
- // client's request for the ListIPSets operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See ListIPSets for more information on using the ListIPSets
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the ListIPSetsRequest method.
- // req, resp := client.ListIPSetsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListIPSets
- func (c *WAFV2) ListIPSetsRequest(input *ListIPSetsInput) (req *request.Request, output *ListIPSetsOutput) {
- op := &request.Operation{
- Name: opListIPSets,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ListIPSetsInput{}
- }
- output = &ListIPSetsOutput{}
- req = c.newRequest(op, input, output)
- return
- }
- // ListIPSets API operation for AWS WAFV2.
- //
- // Retrieves an array of IPSetSummary objects for the IP sets that you manage.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation ListIPSets for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListIPSets
- func (c *WAFV2) ListIPSets(input *ListIPSetsInput) (*ListIPSetsOutput, error) {
- req, out := c.ListIPSetsRequest(input)
- return out, req.Send()
- }
- // ListIPSetsWithContext is the same as ListIPSets with the addition of
- // the ability to pass a context and additional request options.
- //
- // See ListIPSets for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) ListIPSetsWithContext(ctx aws.Context, input *ListIPSetsInput, opts ...request.Option) (*ListIPSetsOutput, error) {
- req, out := c.ListIPSetsRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opListLoggingConfigurations = "ListLoggingConfigurations"
- // ListLoggingConfigurationsRequest generates a "aws/request.Request" representing the
- // client's request for the ListLoggingConfigurations operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See ListLoggingConfigurations for more information on using the ListLoggingConfigurations
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the ListLoggingConfigurationsRequest method.
- // req, resp := client.ListLoggingConfigurationsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListLoggingConfigurations
- func (c *WAFV2) ListLoggingConfigurationsRequest(input *ListLoggingConfigurationsInput) (req *request.Request, output *ListLoggingConfigurationsOutput) {
- op := &request.Operation{
- Name: opListLoggingConfigurations,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ListLoggingConfigurationsInput{}
- }
- output = &ListLoggingConfigurationsOutput{}
- req = c.newRequest(op, input, output)
- return
- }
- // ListLoggingConfigurations API operation for AWS WAFV2.
- //
- // Retrieves an array of your LoggingConfiguration objects.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation ListLoggingConfigurations for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListLoggingConfigurations
- func (c *WAFV2) ListLoggingConfigurations(input *ListLoggingConfigurationsInput) (*ListLoggingConfigurationsOutput, error) {
- req, out := c.ListLoggingConfigurationsRequest(input)
- return out, req.Send()
- }
- // ListLoggingConfigurationsWithContext is the same as ListLoggingConfigurations with the addition of
- // the ability to pass a context and additional request options.
- //
- // See ListLoggingConfigurations for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) ListLoggingConfigurationsWithContext(ctx aws.Context, input *ListLoggingConfigurationsInput, opts ...request.Option) (*ListLoggingConfigurationsOutput, error) {
- req, out := c.ListLoggingConfigurationsRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opListManagedRuleSets = "ListManagedRuleSets"
- // ListManagedRuleSetsRequest generates a "aws/request.Request" representing the
- // client's request for the ListManagedRuleSets operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See ListManagedRuleSets for more information on using the ListManagedRuleSets
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the ListManagedRuleSetsRequest method.
- // req, resp := client.ListManagedRuleSetsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListManagedRuleSets
- func (c *WAFV2) ListManagedRuleSetsRequest(input *ListManagedRuleSetsInput) (req *request.Request, output *ListManagedRuleSetsOutput) {
- op := &request.Operation{
- Name: opListManagedRuleSets,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ListManagedRuleSetsInput{}
- }
- output = &ListManagedRuleSetsOutput{}
- req = c.newRequest(op, input, output)
- return
- }
- // ListManagedRuleSets API operation for AWS WAFV2.
- //
- // Retrieves the managed rule sets that you own.
- //
- // This is intended for use only by vendors of managed rule sets. Vendors are
- // Amazon Web Services and Amazon Web Services Marketplace sellers.
- //
- // Vendors, you can use the managed rule set APIs to provide controlled rollout
- // of your versioned managed rule group offerings for your customers. The APIs
- // are ListManagedRuleSets, GetManagedRuleSet, PutManagedRuleSetVersions, and
- // UpdateManagedRuleSetVersionExpiryDate.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation ListManagedRuleSets for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListManagedRuleSets
- func (c *WAFV2) ListManagedRuleSets(input *ListManagedRuleSetsInput) (*ListManagedRuleSetsOutput, error) {
- req, out := c.ListManagedRuleSetsRequest(input)
- return out, req.Send()
- }
- // ListManagedRuleSetsWithContext is the same as ListManagedRuleSets with the addition of
- // the ability to pass a context and additional request options.
- //
- // See ListManagedRuleSets for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) ListManagedRuleSetsWithContext(ctx aws.Context, input *ListManagedRuleSetsInput, opts ...request.Option) (*ListManagedRuleSetsOutput, error) {
- req, out := c.ListManagedRuleSetsRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opListMobileSdkReleases = "ListMobileSdkReleases"
- // ListMobileSdkReleasesRequest generates a "aws/request.Request" representing the
- // client's request for the ListMobileSdkReleases operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See ListMobileSdkReleases for more information on using the ListMobileSdkReleases
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the ListMobileSdkReleasesRequest method.
- // req, resp := client.ListMobileSdkReleasesRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListMobileSdkReleases
- func (c *WAFV2) ListMobileSdkReleasesRequest(input *ListMobileSdkReleasesInput) (req *request.Request, output *ListMobileSdkReleasesOutput) {
- op := &request.Operation{
- Name: opListMobileSdkReleases,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ListMobileSdkReleasesInput{}
- }
- output = &ListMobileSdkReleasesOutput{}
- req = c.newRequest(op, input, output)
- return
- }
- // ListMobileSdkReleases API operation for AWS WAFV2.
- //
- // Retrieves a list of the available releases for the mobile SDK and the specified
- // device platform.
- //
- // The mobile SDK is not generally available. Customers who have access to the
- // mobile SDK can use it to establish and manage WAF tokens for use in HTTP(S)
- // requests from a mobile device to WAF. For more information, see WAF client
- // application integration (https://docs.aws.amazon.com/waf/latest/developerguide/waf-application-integration.html)
- // in the WAF Developer Guide.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation ListMobileSdkReleases for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListMobileSdkReleases
- func (c *WAFV2) ListMobileSdkReleases(input *ListMobileSdkReleasesInput) (*ListMobileSdkReleasesOutput, error) {
- req, out := c.ListMobileSdkReleasesRequest(input)
- return out, req.Send()
- }
- // ListMobileSdkReleasesWithContext is the same as ListMobileSdkReleases with the addition of
- // the ability to pass a context and additional request options.
- //
- // See ListMobileSdkReleases for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) ListMobileSdkReleasesWithContext(ctx aws.Context, input *ListMobileSdkReleasesInput, opts ...request.Option) (*ListMobileSdkReleasesOutput, error) {
- req, out := c.ListMobileSdkReleasesRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opListRegexPatternSets = "ListRegexPatternSets"
- // ListRegexPatternSetsRequest generates a "aws/request.Request" representing the
- // client's request for the ListRegexPatternSets operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See ListRegexPatternSets for more information on using the ListRegexPatternSets
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the ListRegexPatternSetsRequest method.
- // req, resp := client.ListRegexPatternSetsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListRegexPatternSets
- func (c *WAFV2) ListRegexPatternSetsRequest(input *ListRegexPatternSetsInput) (req *request.Request, output *ListRegexPatternSetsOutput) {
- op := &request.Operation{
- Name: opListRegexPatternSets,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ListRegexPatternSetsInput{}
- }
- output = &ListRegexPatternSetsOutput{}
- req = c.newRequest(op, input, output)
- return
- }
- // ListRegexPatternSets API operation for AWS WAFV2.
- //
- // Retrieves an array of RegexPatternSetSummary objects for the regex pattern
- // sets that you manage.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation ListRegexPatternSets for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListRegexPatternSets
- func (c *WAFV2) ListRegexPatternSets(input *ListRegexPatternSetsInput) (*ListRegexPatternSetsOutput, error) {
- req, out := c.ListRegexPatternSetsRequest(input)
- return out, req.Send()
- }
- // ListRegexPatternSetsWithContext is the same as ListRegexPatternSets with the addition of
- // the ability to pass a context and additional request options.
- //
- // See ListRegexPatternSets for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) ListRegexPatternSetsWithContext(ctx aws.Context, input *ListRegexPatternSetsInput, opts ...request.Option) (*ListRegexPatternSetsOutput, error) {
- req, out := c.ListRegexPatternSetsRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opListResourcesForWebACL = "ListResourcesForWebACL"
- // ListResourcesForWebACLRequest generates a "aws/request.Request" representing the
- // client's request for the ListResourcesForWebACL operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See ListResourcesForWebACL for more information on using the ListResourcesForWebACL
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the ListResourcesForWebACLRequest method.
- // req, resp := client.ListResourcesForWebACLRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListResourcesForWebACL
- func (c *WAFV2) ListResourcesForWebACLRequest(input *ListResourcesForWebACLInput) (req *request.Request, output *ListResourcesForWebACLOutput) {
- op := &request.Operation{
- Name: opListResourcesForWebACL,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ListResourcesForWebACLInput{}
- }
- output = &ListResourcesForWebACLOutput{}
- req = c.newRequest(op, input, output)
- return
- }
- // ListResourcesForWebACL API operation for AWS WAFV2.
- //
- // Retrieves an array of the Amazon Resource Names (ARNs) for the regional resources
- // that are associated with the specified web ACL. If you want the list of Amazon
- // CloudFront resources, use the CloudFront call ListDistributionsByWebACLId.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation ListResourcesForWebACL for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFNonexistentItemException
- // WAF couldn’t perform the operation because your resource doesn't exist.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListResourcesForWebACL
- func (c *WAFV2) ListResourcesForWebACL(input *ListResourcesForWebACLInput) (*ListResourcesForWebACLOutput, error) {
- req, out := c.ListResourcesForWebACLRequest(input)
- return out, req.Send()
- }
- // ListResourcesForWebACLWithContext is the same as ListResourcesForWebACL with the addition of
- // the ability to pass a context and additional request options.
- //
- // See ListResourcesForWebACL for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) ListResourcesForWebACLWithContext(ctx aws.Context, input *ListResourcesForWebACLInput, opts ...request.Option) (*ListResourcesForWebACLOutput, error) {
- req, out := c.ListResourcesForWebACLRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opListRuleGroups = "ListRuleGroups"
- // ListRuleGroupsRequest generates a "aws/request.Request" representing the
- // client's request for the ListRuleGroups operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See ListRuleGroups for more information on using the ListRuleGroups
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the ListRuleGroupsRequest method.
- // req, resp := client.ListRuleGroupsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListRuleGroups
- func (c *WAFV2) ListRuleGroupsRequest(input *ListRuleGroupsInput) (req *request.Request, output *ListRuleGroupsOutput) {
- op := &request.Operation{
- Name: opListRuleGroups,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ListRuleGroupsInput{}
- }
- output = &ListRuleGroupsOutput{}
- req = c.newRequest(op, input, output)
- return
- }
- // ListRuleGroups API operation for AWS WAFV2.
- //
- // Retrieves an array of RuleGroupSummary objects for the rule groups that you
- // manage.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation ListRuleGroups for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListRuleGroups
- func (c *WAFV2) ListRuleGroups(input *ListRuleGroupsInput) (*ListRuleGroupsOutput, error) {
- req, out := c.ListRuleGroupsRequest(input)
- return out, req.Send()
- }
- // ListRuleGroupsWithContext is the same as ListRuleGroups with the addition of
- // the ability to pass a context and additional request options.
- //
- // See ListRuleGroups for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) ListRuleGroupsWithContext(ctx aws.Context, input *ListRuleGroupsInput, opts ...request.Option) (*ListRuleGroupsOutput, error) {
- req, out := c.ListRuleGroupsRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opListTagsForResource = "ListTagsForResource"
- // ListTagsForResourceRequest generates a "aws/request.Request" representing the
- // client's request for the ListTagsForResource operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See ListTagsForResource for more information on using the ListTagsForResource
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the ListTagsForResourceRequest method.
- // req, resp := client.ListTagsForResourceRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListTagsForResource
- func (c *WAFV2) ListTagsForResourceRequest(input *ListTagsForResourceInput) (req *request.Request, output *ListTagsForResourceOutput) {
- op := &request.Operation{
- Name: opListTagsForResource,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ListTagsForResourceInput{}
- }
- output = &ListTagsForResourceOutput{}
- req = c.newRequest(op, input, output)
- return
- }
- // ListTagsForResource API operation for AWS WAFV2.
- //
- // Retrieves the TagInfoForResource for the specified resource. Tags are key:value
- // pairs that you can use to categorize and manage your resources, for purposes
- // like billing. For example, you might set the tag key to "customer" and the
- // value to the customer name or ID. You can specify one or more tags to add
- // to each Amazon Web Services resource, up to 50 tags for a resource.
- //
- // You can tag the Amazon Web Services resources that you manage through WAF:
- // web ACLs, rule groups, IP sets, and regex pattern sets. You can't manage
- // or view tags through the WAF console.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation ListTagsForResource for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFNonexistentItemException
- // WAF couldn’t perform the operation because your resource doesn't exist.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate.
- //
- // - WAFTagOperationException
- // An error occurred during the tagging operation. Retry your request.
- //
- // - WAFTagOperationInternalErrorException
- // WAF couldn’t perform your tagging operation because of an internal error.
- // Retry your request.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListTagsForResource
- func (c *WAFV2) ListTagsForResource(input *ListTagsForResourceInput) (*ListTagsForResourceOutput, error) {
- req, out := c.ListTagsForResourceRequest(input)
- return out, req.Send()
- }
- // ListTagsForResourceWithContext is the same as ListTagsForResource with the addition of
- // the ability to pass a context and additional request options.
- //
- // See ListTagsForResource for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) ListTagsForResourceWithContext(ctx aws.Context, input *ListTagsForResourceInput, opts ...request.Option) (*ListTagsForResourceOutput, error) {
- req, out := c.ListTagsForResourceRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opListWebACLs = "ListWebACLs"
- // ListWebACLsRequest generates a "aws/request.Request" representing the
- // client's request for the ListWebACLs operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See ListWebACLs for more information on using the ListWebACLs
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the ListWebACLsRequest method.
- // req, resp := client.ListWebACLsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListWebACLs
- func (c *WAFV2) ListWebACLsRequest(input *ListWebACLsInput) (req *request.Request, output *ListWebACLsOutput) {
- op := &request.Operation{
- Name: opListWebACLs,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &ListWebACLsInput{}
- }
- output = &ListWebACLsOutput{}
- req = c.newRequest(op, input, output)
- return
- }
- // ListWebACLs API operation for AWS WAFV2.
- //
- // Retrieves an array of WebACLSummary objects for the web ACLs that you manage.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation ListWebACLs for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListWebACLs
- func (c *WAFV2) ListWebACLs(input *ListWebACLsInput) (*ListWebACLsOutput, error) {
- req, out := c.ListWebACLsRequest(input)
- return out, req.Send()
- }
- // ListWebACLsWithContext is the same as ListWebACLs with the addition of
- // the ability to pass a context and additional request options.
- //
- // See ListWebACLs for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) ListWebACLsWithContext(ctx aws.Context, input *ListWebACLsInput, opts ...request.Option) (*ListWebACLsOutput, error) {
- req, out := c.ListWebACLsRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opPutLoggingConfiguration = "PutLoggingConfiguration"
- // PutLoggingConfigurationRequest generates a "aws/request.Request" representing the
- // client's request for the PutLoggingConfiguration operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See PutLoggingConfiguration for more information on using the PutLoggingConfiguration
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the PutLoggingConfigurationRequest method.
- // req, resp := client.PutLoggingConfigurationRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/PutLoggingConfiguration
- func (c *WAFV2) PutLoggingConfigurationRequest(input *PutLoggingConfigurationInput) (req *request.Request, output *PutLoggingConfigurationOutput) {
- op := &request.Operation{
- Name: opPutLoggingConfiguration,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &PutLoggingConfigurationInput{}
- }
- output = &PutLoggingConfigurationOutput{}
- req = c.newRequest(op, input, output)
- return
- }
- // PutLoggingConfiguration API operation for AWS WAFV2.
- //
- // Enables the specified LoggingConfiguration, to start logging from a web ACL,
- // according to the configuration provided.
- //
- // This operation completely replaces any mutable specifications that you already
- // have for a logging configuration with the ones that you provide to this call.
- //
- // To modify an existing logging configuration, do the following:
- //
- // # Retrieve it by calling GetLoggingConfiguration
- //
- // # Update its settings as needed
- //
- // # Provide the complete logging configuration specification to this call
- //
- // You can define one logging destination per web ACL.
- //
- // You can access information about the traffic that WAF inspects using the
- // following steps:
- //
- // Create your logging destination. You can use an Amazon CloudWatch Logs log
- // group, an Amazon Simple Storage Service (Amazon S3) bucket, or an Amazon
- // Kinesis Data Firehose.
- //
- // The name that you give the destination must start with aws-waf-logs-. Depending
- // on the type of destination, you might need to configure additional settings
- // or permissions.
- //
- // For configuration requirements and pricing information for each destination
- // type, see Logging web ACL traffic (https://docs.aws.amazon.com/waf/latest/developerguide/logging.html)
- // in the WAF Developer Guide.
- //
- // Associate your logging destination to your web ACL using a PutLoggingConfiguration
- // request.
- //
- // When you successfully enable logging using a PutLoggingConfiguration request,
- // WAF creates an additional role or policy that is required to write logs to
- // the logging destination. For an Amazon CloudWatch Logs log group, WAF creates
- // a resource policy on the log group. For an Amazon S3 bucket, WAF creates
- // a bucket policy. For an Amazon Kinesis Data Firehose, WAF creates a service-linked
- // role.
- //
- // For additional information about web ACL logging, see Logging web ACL traffic
- // information (https://docs.aws.amazon.com/waf/latest/developerguide/logging.html)
- // in the WAF Developer Guide.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation PutLoggingConfiguration for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFNonexistentItemException
- // WAF couldn’t perform the operation because your resource doesn't exist.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate.
- //
- // - WAFOptimisticLockException
- // WAF couldn’t save your changes because you tried to update or delete a
- // resource that has changed since you last retrieved it. Get the resource again,
- // make any changes you need to make to the new copy, and retry your operation.
- //
- // - WAFServiceLinkedRoleErrorException
- // WAF is not able to access the service linked role. This can be caused by
- // a previous PutLoggingConfiguration request, which can lock the service linked
- // role for about 20 seconds. Please try your request again. The service linked
- // role can also be locked by a previous DeleteServiceLinkedRole request, which
- // can lock the role for 15 minutes or more. If you recently made a call to
- // DeleteServiceLinkedRole, wait at least 15 minutes and try the request again.
- // If you receive this same exception again, you will have to wait additional
- // time until the role is unlocked.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // - WAFLimitsExceededException
- // WAF couldn’t perform the operation because you exceeded your resource limit.
- // For example, the maximum number of WebACL objects that you can create for
- // an Amazon Web Services account. For more information, see WAF quotas (https://docs.aws.amazon.com/waf/latest/developerguide/limits.html)
- // in the WAF Developer Guide.
- //
- // - WAFLogDestinationPermissionIssueException
- // The operation failed because you don't have the permissions that your logging
- // configuration requires. For information, see Logging web ACL traffic information
- // (https://docs.aws.amazon.com/waf/latest/developerguide/logging.html) in the
- // WAF Developer Guide.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/PutLoggingConfiguration
- func (c *WAFV2) PutLoggingConfiguration(input *PutLoggingConfigurationInput) (*PutLoggingConfigurationOutput, error) {
- req, out := c.PutLoggingConfigurationRequest(input)
- return out, req.Send()
- }
- // PutLoggingConfigurationWithContext is the same as PutLoggingConfiguration with the addition of
- // the ability to pass a context and additional request options.
- //
- // See PutLoggingConfiguration for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) PutLoggingConfigurationWithContext(ctx aws.Context, input *PutLoggingConfigurationInput, opts ...request.Option) (*PutLoggingConfigurationOutput, error) {
- req, out := c.PutLoggingConfigurationRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opPutManagedRuleSetVersions = "PutManagedRuleSetVersions"
- // PutManagedRuleSetVersionsRequest generates a "aws/request.Request" representing the
- // client's request for the PutManagedRuleSetVersions operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See PutManagedRuleSetVersions for more information on using the PutManagedRuleSetVersions
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the PutManagedRuleSetVersionsRequest method.
- // req, resp := client.PutManagedRuleSetVersionsRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/PutManagedRuleSetVersions
- func (c *WAFV2) PutManagedRuleSetVersionsRequest(input *PutManagedRuleSetVersionsInput) (req *request.Request, output *PutManagedRuleSetVersionsOutput) {
- op := &request.Operation{
- Name: opPutManagedRuleSetVersions,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &PutManagedRuleSetVersionsInput{}
- }
- output = &PutManagedRuleSetVersionsOutput{}
- req = c.newRequest(op, input, output)
- return
- }
- // PutManagedRuleSetVersions API operation for AWS WAFV2.
- //
- // Defines the versions of your managed rule set that you are offering to the
- // customers. Customers see your offerings as managed rule groups with versioning.
- //
- // This is intended for use only by vendors of managed rule sets. Vendors are
- // Amazon Web Services and Amazon Web Services Marketplace sellers.
- //
- // Vendors, you can use the managed rule set APIs to provide controlled rollout
- // of your versioned managed rule group offerings for your customers. The APIs
- // are ListManagedRuleSets, GetManagedRuleSet, PutManagedRuleSetVersions, and
- // UpdateManagedRuleSetVersionExpiryDate.
- //
- // Customers retrieve their managed rule group list by calling ListAvailableManagedRuleGroups.
- // The name that you provide here for your managed rule set is the name the
- // customer sees for the corresponding managed rule group. Customers can retrieve
- // the available versions for a managed rule group by calling ListAvailableManagedRuleGroupVersions.
- // You provide a rule group specification for each version. For each managed
- // rule set, you must specify a version that you recommend using.
- //
- // To initiate the expiration of a managed rule group version, use UpdateManagedRuleSetVersionExpiryDate.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation PutManagedRuleSetVersions for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFNonexistentItemException
- // WAF couldn’t perform the operation because your resource doesn't exist.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate.
- //
- // - WAFOptimisticLockException
- // WAF couldn’t save your changes because you tried to update or delete a
- // resource that has changed since you last retrieved it. Get the resource again,
- // make any changes you need to make to the new copy, and retry your operation.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/PutManagedRuleSetVersions
- func (c *WAFV2) PutManagedRuleSetVersions(input *PutManagedRuleSetVersionsInput) (*PutManagedRuleSetVersionsOutput, error) {
- req, out := c.PutManagedRuleSetVersionsRequest(input)
- return out, req.Send()
- }
- // PutManagedRuleSetVersionsWithContext is the same as PutManagedRuleSetVersions with the addition of
- // the ability to pass a context and additional request options.
- //
- // See PutManagedRuleSetVersions for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) PutManagedRuleSetVersionsWithContext(ctx aws.Context, input *PutManagedRuleSetVersionsInput, opts ...request.Option) (*PutManagedRuleSetVersionsOutput, error) {
- req, out := c.PutManagedRuleSetVersionsRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opPutPermissionPolicy = "PutPermissionPolicy"
- // PutPermissionPolicyRequest generates a "aws/request.Request" representing the
- // client's request for the PutPermissionPolicy operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See PutPermissionPolicy for more information on using the PutPermissionPolicy
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the PutPermissionPolicyRequest method.
- // req, resp := client.PutPermissionPolicyRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/PutPermissionPolicy
- func (c *WAFV2) PutPermissionPolicyRequest(input *PutPermissionPolicyInput) (req *request.Request, output *PutPermissionPolicyOutput) {
- op := &request.Operation{
- Name: opPutPermissionPolicy,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &PutPermissionPolicyInput{}
- }
- output = &PutPermissionPolicyOutput{}
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Swap(jsonrpc.UnmarshalHandler.Name, protocol.UnmarshalDiscardBodyHandler)
- return
- }
- // PutPermissionPolicy API operation for AWS WAFV2.
- //
- // Attaches an IAM policy to the specified resource. Use this to share a rule
- // group across accounts.
- //
- // You must be the owner of the rule group to perform this operation.
- //
- // This action is subject to the following restrictions:
- //
- // - You can attach only one policy with each PutPermissionPolicy request.
- //
- // - The ARN in the request must be a valid WAF RuleGroup ARN and the rule
- // group must exist in the same Region.
- //
- // - The user making the request must be the owner of the rule group.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation PutPermissionPolicy for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFNonexistentItemException
- // WAF couldn’t perform the operation because your resource doesn't exist.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate.
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFInvalidPermissionPolicyException
- // The operation failed because the specified policy isn't in the proper format.
- //
- // The policy specifications must conform to the following:
- //
- // - The policy must be composed using IAM Policy version 2012-10-17 or version
- // 2015-01-01.
- //
- // - The policy must include specifications for Effect, Action, and Principal.
- //
- // - Effect must specify Allow.
- //
- // - Action must specify wafv2:CreateWebACL, wafv2:UpdateWebACL, and wafv2:PutFirewallManagerRuleGroups
- // and may optionally specify wafv2:GetRuleGroup. WAF rejects any extra actions
- // or wildcard actions in the policy.
- //
- // - The policy must not include a Resource parameter.
- //
- // For more information, see IAM Policies (https://docs.aws.amazon.com/IAM/latest/UserGuide/access_policies.html).
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/PutPermissionPolicy
- func (c *WAFV2) PutPermissionPolicy(input *PutPermissionPolicyInput) (*PutPermissionPolicyOutput, error) {
- req, out := c.PutPermissionPolicyRequest(input)
- return out, req.Send()
- }
- // PutPermissionPolicyWithContext is the same as PutPermissionPolicy with the addition of
- // the ability to pass a context and additional request options.
- //
- // See PutPermissionPolicy for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) PutPermissionPolicyWithContext(ctx aws.Context, input *PutPermissionPolicyInput, opts ...request.Option) (*PutPermissionPolicyOutput, error) {
- req, out := c.PutPermissionPolicyRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opTagResource = "TagResource"
- // TagResourceRequest generates a "aws/request.Request" representing the
- // client's request for the TagResource operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See TagResource for more information on using the TagResource
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the TagResourceRequest method.
- // req, resp := client.TagResourceRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/TagResource
- func (c *WAFV2) TagResourceRequest(input *TagResourceInput) (req *request.Request, output *TagResourceOutput) {
- op := &request.Operation{
- Name: opTagResource,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &TagResourceInput{}
- }
- output = &TagResourceOutput{}
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Swap(jsonrpc.UnmarshalHandler.Name, protocol.UnmarshalDiscardBodyHandler)
- return
- }
- // TagResource API operation for AWS WAFV2.
- //
- // Associates tags with the specified Amazon Web Services resource. Tags are
- // key:value pairs that you can use to categorize and manage your resources,
- // for purposes like billing. For example, you might set the tag key to "customer"
- // and the value to the customer name or ID. You can specify one or more tags
- // to add to each Amazon Web Services resource, up to 50 tags for a resource.
- //
- // You can tag the Amazon Web Services resources that you manage through WAF:
- // web ACLs, rule groups, IP sets, and regex pattern sets. You can't manage
- // or view tags through the WAF console.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation TagResource for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFLimitsExceededException
- // WAF couldn’t perform the operation because you exceeded your resource limit.
- // For example, the maximum number of WebACL objects that you can create for
- // an Amazon Web Services account. For more information, see WAF quotas (https://docs.aws.amazon.com/waf/latest/developerguide/limits.html)
- // in the WAF Developer Guide.
- //
- // - WAFNonexistentItemException
- // WAF couldn’t perform the operation because your resource doesn't exist.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate.
- //
- // - WAFTagOperationException
- // An error occurred during the tagging operation. Retry your request.
- //
- // - WAFTagOperationInternalErrorException
- // WAF couldn’t perform your tagging operation because of an internal error.
- // Retry your request.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/TagResource
- func (c *WAFV2) TagResource(input *TagResourceInput) (*TagResourceOutput, error) {
- req, out := c.TagResourceRequest(input)
- return out, req.Send()
- }
- // TagResourceWithContext is the same as TagResource with the addition of
- // the ability to pass a context and additional request options.
- //
- // See TagResource for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) TagResourceWithContext(ctx aws.Context, input *TagResourceInput, opts ...request.Option) (*TagResourceOutput, error) {
- req, out := c.TagResourceRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opUntagResource = "UntagResource"
- // UntagResourceRequest generates a "aws/request.Request" representing the
- // client's request for the UntagResource operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See UntagResource for more information on using the UntagResource
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the UntagResourceRequest method.
- // req, resp := client.UntagResourceRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/UntagResource
- func (c *WAFV2) UntagResourceRequest(input *UntagResourceInput) (req *request.Request, output *UntagResourceOutput) {
- op := &request.Operation{
- Name: opUntagResource,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &UntagResourceInput{}
- }
- output = &UntagResourceOutput{}
- req = c.newRequest(op, input, output)
- req.Handlers.Unmarshal.Swap(jsonrpc.UnmarshalHandler.Name, protocol.UnmarshalDiscardBodyHandler)
- return
- }
- // UntagResource API operation for AWS WAFV2.
- //
- // Disassociates tags from an Amazon Web Services resource. Tags are key:value
- // pairs that you can associate with Amazon Web Services resources. For example,
- // the tag key might be "customer" and the tag value might be "companyA." You
- // can specify one or more tags to add to each container. You can add up to
- // 50 tags to each Amazon Web Services resource.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation UntagResource for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFNonexistentItemException
- // WAF couldn’t perform the operation because your resource doesn't exist.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate.
- //
- // - WAFTagOperationException
- // An error occurred during the tagging operation. Retry your request.
- //
- // - WAFTagOperationInternalErrorException
- // WAF couldn’t perform your tagging operation because of an internal error.
- // Retry your request.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/UntagResource
- func (c *WAFV2) UntagResource(input *UntagResourceInput) (*UntagResourceOutput, error) {
- req, out := c.UntagResourceRequest(input)
- return out, req.Send()
- }
- // UntagResourceWithContext is the same as UntagResource with the addition of
- // the ability to pass a context and additional request options.
- //
- // See UntagResource for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) UntagResourceWithContext(ctx aws.Context, input *UntagResourceInput, opts ...request.Option) (*UntagResourceOutput, error) {
- req, out := c.UntagResourceRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opUpdateIPSet = "UpdateIPSet"
- // UpdateIPSetRequest generates a "aws/request.Request" representing the
- // client's request for the UpdateIPSet operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See UpdateIPSet for more information on using the UpdateIPSet
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the UpdateIPSetRequest method.
- // req, resp := client.UpdateIPSetRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/UpdateIPSet
- func (c *WAFV2) UpdateIPSetRequest(input *UpdateIPSetInput) (req *request.Request, output *UpdateIPSetOutput) {
- op := &request.Operation{
- Name: opUpdateIPSet,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &UpdateIPSetInput{}
- }
- output = &UpdateIPSetOutput{}
- req = c.newRequest(op, input, output)
- return
- }
- // UpdateIPSet API operation for AWS WAFV2.
- //
- // Updates the specified IPSet.
- //
- // This operation completely replaces the mutable specifications that you already
- // have for the IP set with the ones that you provide to this call.
- //
- // To modify an IP set, do the following:
- //
- // # Retrieve it by calling GetIPSet
- //
- // # Update its settings as needed
- //
- // # Provide the complete IP set specification to this call
- //
- // When you make changes to web ACLs or web ACL components, like rules and rule
- // groups, WAF propagates the changes everywhere that the web ACL and its components
- // are stored and used. Your changes are applied within seconds, but there might
- // be a brief period of inconsistency when the changes have arrived in some
- // places and not in others. So, for example, if you change a rule action setting,
- // the action might be the old action in one area and the new action in another
- // area. Or if you add an IP address to an IP set used in a blocking rule, the
- // new address might briefly be blocked in one area while still allowed in another.
- // This temporary inconsistency can occur when you first associate a web ACL
- // with an Amazon Web Services resource and when you change a web ACL that is
- // already associated with a resource. Generally, any inconsistencies of this
- // type last only a few seconds.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation UpdateIPSet for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFNonexistentItemException
- // WAF couldn’t perform the operation because your resource doesn't exist.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate.
- //
- // - WAFDuplicateItemException
- // WAF couldn’t perform the operation because the resource that you tried
- // to save is a duplicate of an existing one.
- //
- // - WAFOptimisticLockException
- // WAF couldn’t save your changes because you tried to update or delete a
- // resource that has changed since you last retrieved it. Get the resource again,
- // make any changes you need to make to the new copy, and retry your operation.
- //
- // - WAFLimitsExceededException
- // WAF couldn’t perform the operation because you exceeded your resource limit.
- // For example, the maximum number of WebACL objects that you can create for
- // an Amazon Web Services account. For more information, see WAF quotas (https://docs.aws.amazon.com/waf/latest/developerguide/limits.html)
- // in the WAF Developer Guide.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/UpdateIPSet
- func (c *WAFV2) UpdateIPSet(input *UpdateIPSetInput) (*UpdateIPSetOutput, error) {
- req, out := c.UpdateIPSetRequest(input)
- return out, req.Send()
- }
- // UpdateIPSetWithContext is the same as UpdateIPSet with the addition of
- // the ability to pass a context and additional request options.
- //
- // See UpdateIPSet for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) UpdateIPSetWithContext(ctx aws.Context, input *UpdateIPSetInput, opts ...request.Option) (*UpdateIPSetOutput, error) {
- req, out := c.UpdateIPSetRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opUpdateManagedRuleSetVersionExpiryDate = "UpdateManagedRuleSetVersionExpiryDate"
- // UpdateManagedRuleSetVersionExpiryDateRequest generates a "aws/request.Request" representing the
- // client's request for the UpdateManagedRuleSetVersionExpiryDate operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See UpdateManagedRuleSetVersionExpiryDate for more information on using the UpdateManagedRuleSetVersionExpiryDate
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the UpdateManagedRuleSetVersionExpiryDateRequest method.
- // req, resp := client.UpdateManagedRuleSetVersionExpiryDateRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/UpdateManagedRuleSetVersionExpiryDate
- func (c *WAFV2) UpdateManagedRuleSetVersionExpiryDateRequest(input *UpdateManagedRuleSetVersionExpiryDateInput) (req *request.Request, output *UpdateManagedRuleSetVersionExpiryDateOutput) {
- op := &request.Operation{
- Name: opUpdateManagedRuleSetVersionExpiryDate,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &UpdateManagedRuleSetVersionExpiryDateInput{}
- }
- output = &UpdateManagedRuleSetVersionExpiryDateOutput{}
- req = c.newRequest(op, input, output)
- return
- }
- // UpdateManagedRuleSetVersionExpiryDate API operation for AWS WAFV2.
- //
- // Updates the expiration information for your managed rule set. Use this to
- // initiate the expiration of a managed rule group version. After you initiate
- // expiration for a version, WAF excludes it from the response to ListAvailableManagedRuleGroupVersions
- // for the managed rule group.
- //
- // This is intended for use only by vendors of managed rule sets. Vendors are
- // Amazon Web Services and Amazon Web Services Marketplace sellers.
- //
- // Vendors, you can use the managed rule set APIs to provide controlled rollout
- // of your versioned managed rule group offerings for your customers. The APIs
- // are ListManagedRuleSets, GetManagedRuleSet, PutManagedRuleSetVersions, and
- // UpdateManagedRuleSetVersionExpiryDate.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation UpdateManagedRuleSetVersionExpiryDate for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFNonexistentItemException
- // WAF couldn’t perform the operation because your resource doesn't exist.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate.
- //
- // - WAFOptimisticLockException
- // WAF couldn’t save your changes because you tried to update or delete a
- // resource that has changed since you last retrieved it. Get the resource again,
- // make any changes you need to make to the new copy, and retry your operation.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/UpdateManagedRuleSetVersionExpiryDate
- func (c *WAFV2) UpdateManagedRuleSetVersionExpiryDate(input *UpdateManagedRuleSetVersionExpiryDateInput) (*UpdateManagedRuleSetVersionExpiryDateOutput, error) {
- req, out := c.UpdateManagedRuleSetVersionExpiryDateRequest(input)
- return out, req.Send()
- }
- // UpdateManagedRuleSetVersionExpiryDateWithContext is the same as UpdateManagedRuleSetVersionExpiryDate with the addition of
- // the ability to pass a context and additional request options.
- //
- // See UpdateManagedRuleSetVersionExpiryDate for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) UpdateManagedRuleSetVersionExpiryDateWithContext(ctx aws.Context, input *UpdateManagedRuleSetVersionExpiryDateInput, opts ...request.Option) (*UpdateManagedRuleSetVersionExpiryDateOutput, error) {
- req, out := c.UpdateManagedRuleSetVersionExpiryDateRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opUpdateRegexPatternSet = "UpdateRegexPatternSet"
- // UpdateRegexPatternSetRequest generates a "aws/request.Request" representing the
- // client's request for the UpdateRegexPatternSet operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See UpdateRegexPatternSet for more information on using the UpdateRegexPatternSet
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the UpdateRegexPatternSetRequest method.
- // req, resp := client.UpdateRegexPatternSetRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/UpdateRegexPatternSet
- func (c *WAFV2) UpdateRegexPatternSetRequest(input *UpdateRegexPatternSetInput) (req *request.Request, output *UpdateRegexPatternSetOutput) {
- op := &request.Operation{
- Name: opUpdateRegexPatternSet,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &UpdateRegexPatternSetInput{}
- }
- output = &UpdateRegexPatternSetOutput{}
- req = c.newRequest(op, input, output)
- return
- }
- // UpdateRegexPatternSet API operation for AWS WAFV2.
- //
- // Updates the specified RegexPatternSet.
- //
- // This operation completely replaces the mutable specifications that you already
- // have for the regex pattern set with the ones that you provide to this call.
- //
- // To modify a regex pattern set, do the following:
- //
- // # Retrieve it by calling GetRegexPatternSet
- //
- // # Update its settings as needed
- //
- // # Provide the complete regex pattern set specification to this call
- //
- // When you make changes to web ACLs or web ACL components, like rules and rule
- // groups, WAF propagates the changes everywhere that the web ACL and its components
- // are stored and used. Your changes are applied within seconds, but there might
- // be a brief period of inconsistency when the changes have arrived in some
- // places and not in others. So, for example, if you change a rule action setting,
- // the action might be the old action in one area and the new action in another
- // area. Or if you add an IP address to an IP set used in a blocking rule, the
- // new address might briefly be blocked in one area while still allowed in another.
- // This temporary inconsistency can occur when you first associate a web ACL
- // with an Amazon Web Services resource and when you change a web ACL that is
- // already associated with a resource. Generally, any inconsistencies of this
- // type last only a few seconds.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation UpdateRegexPatternSet for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFNonexistentItemException
- // WAF couldn’t perform the operation because your resource doesn't exist.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate.
- //
- // - WAFDuplicateItemException
- // WAF couldn’t perform the operation because the resource that you tried
- // to save is a duplicate of an existing one.
- //
- // - WAFOptimisticLockException
- // WAF couldn’t save your changes because you tried to update or delete a
- // resource that has changed since you last retrieved it. Get the resource again,
- // make any changes you need to make to the new copy, and retry your operation.
- //
- // - WAFLimitsExceededException
- // WAF couldn’t perform the operation because you exceeded your resource limit.
- // For example, the maximum number of WebACL objects that you can create for
- // an Amazon Web Services account. For more information, see WAF quotas (https://docs.aws.amazon.com/waf/latest/developerguide/limits.html)
- // in the WAF Developer Guide.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/UpdateRegexPatternSet
- func (c *WAFV2) UpdateRegexPatternSet(input *UpdateRegexPatternSetInput) (*UpdateRegexPatternSetOutput, error) {
- req, out := c.UpdateRegexPatternSetRequest(input)
- return out, req.Send()
- }
- // UpdateRegexPatternSetWithContext is the same as UpdateRegexPatternSet with the addition of
- // the ability to pass a context and additional request options.
- //
- // See UpdateRegexPatternSet for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) UpdateRegexPatternSetWithContext(ctx aws.Context, input *UpdateRegexPatternSetInput, opts ...request.Option) (*UpdateRegexPatternSetOutput, error) {
- req, out := c.UpdateRegexPatternSetRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opUpdateRuleGroup = "UpdateRuleGroup"
- // UpdateRuleGroupRequest generates a "aws/request.Request" representing the
- // client's request for the UpdateRuleGroup operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See UpdateRuleGroup for more information on using the UpdateRuleGroup
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the UpdateRuleGroupRequest method.
- // req, resp := client.UpdateRuleGroupRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/UpdateRuleGroup
- func (c *WAFV2) UpdateRuleGroupRequest(input *UpdateRuleGroupInput) (req *request.Request, output *UpdateRuleGroupOutput) {
- op := &request.Operation{
- Name: opUpdateRuleGroup,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &UpdateRuleGroupInput{}
- }
- output = &UpdateRuleGroupOutput{}
- req = c.newRequest(op, input, output)
- return
- }
- // UpdateRuleGroup API operation for AWS WAFV2.
- //
- // Updates the specified RuleGroup.
- //
- // This operation completely replaces the mutable specifications that you already
- // have for the rule group with the ones that you provide to this call.
- //
- // To modify a rule group, do the following:
- //
- // # Retrieve it by calling GetRuleGroup
- //
- // # Update its settings as needed
- //
- // # Provide the complete rule group specification to this call
- //
- // When you make changes to web ACLs or web ACL components, like rules and rule
- // groups, WAF propagates the changes everywhere that the web ACL and its components
- // are stored and used. Your changes are applied within seconds, but there might
- // be a brief period of inconsistency when the changes have arrived in some
- // places and not in others. So, for example, if you change a rule action setting,
- // the action might be the old action in one area and the new action in another
- // area. Or if you add an IP address to an IP set used in a blocking rule, the
- // new address might briefly be blocked in one area while still allowed in another.
- // This temporary inconsistency can occur when you first associate a web ACL
- // with an Amazon Web Services resource and when you change a web ACL that is
- // already associated with a resource. Generally, any inconsistencies of this
- // type last only a few seconds.
- //
- // A rule group defines a collection of rules to inspect and control web requests
- // that you can use in a WebACL. When you create a rule group, you define an
- // immutable capacity limit. If you update a rule group, you must stay within
- // the capacity. This allows others to reuse the rule group with confidence
- // in its capacity requirements.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation UpdateRuleGroup for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFNonexistentItemException
- // WAF couldn’t perform the operation because your resource doesn't exist.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate.
- //
- // - WAFDuplicateItemException
- // WAF couldn’t perform the operation because the resource that you tried
- // to save is a duplicate of an existing one.
- //
- // - WAFOptimisticLockException
- // WAF couldn’t save your changes because you tried to update or delete a
- // resource that has changed since you last retrieved it. Get the resource again,
- // make any changes you need to make to the new copy, and retry your operation.
- //
- // - WAFLimitsExceededException
- // WAF couldn’t perform the operation because you exceeded your resource limit.
- // For example, the maximum number of WebACL objects that you can create for
- // an Amazon Web Services account. For more information, see WAF quotas (https://docs.aws.amazon.com/waf/latest/developerguide/limits.html)
- // in the WAF Developer Guide.
- //
- // - WAFUnavailableEntityException
- // WAF couldn’t retrieve a resource that you specified for this operation.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate. Verify the resources that you
- // are specifying in your request parameters and then retry the operation.
- //
- // - WAFSubscriptionNotFoundException
- // You tried to use a managed rule group that's available by subscription, but
- // you aren't subscribed to it yet.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // - WAFConfigurationWarningException
- // The operation failed because you are inspecting the web request body, headers,
- // or cookies without specifying how to handle oversize components. Rules that
- // inspect the body must either provide an OversizeHandling configuration or
- // they must be preceded by a SizeConstraintStatement that blocks the body content
- // from being too large. Rules that inspect the headers or cookies must provide
- // an OversizeHandling configuration.
- //
- // Provide the handling configuration and retry your operation.
- //
- // Alternately, you can suppress this warning by adding the following tag to
- // the resource that you provide to this operation: Tag (key:WAF:OversizeFieldsHandlingConstraintOptOut,
- // value:true).
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/UpdateRuleGroup
- func (c *WAFV2) UpdateRuleGroup(input *UpdateRuleGroupInput) (*UpdateRuleGroupOutput, error) {
- req, out := c.UpdateRuleGroupRequest(input)
- return out, req.Send()
- }
- // UpdateRuleGroupWithContext is the same as UpdateRuleGroup with the addition of
- // the ability to pass a context and additional request options.
- //
- // See UpdateRuleGroup for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) UpdateRuleGroupWithContext(ctx aws.Context, input *UpdateRuleGroupInput, opts ...request.Option) (*UpdateRuleGroupOutput, error) {
- req, out := c.UpdateRuleGroupRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- const opUpdateWebACL = "UpdateWebACL"
- // UpdateWebACLRequest generates a "aws/request.Request" representing the
- // client's request for the UpdateWebACL operation. The "output" return
- // value will be populated with the request's response once the request completes
- // successfully.
- //
- // Use "Send" method on the returned Request to send the API call to the service.
- // the "output" return value is not valid until after Send returns without error.
- //
- // See UpdateWebACL for more information on using the UpdateWebACL
- // API call, and error handling.
- //
- // This method is useful when you want to inject custom logic or configuration
- // into the SDK's request lifecycle. Such as custom headers, or retry logic.
- //
- // // Example sending a request using the UpdateWebACLRequest method.
- // req, resp := client.UpdateWebACLRequest(params)
- //
- // err := req.Send()
- // if err == nil { // resp is now filled
- // fmt.Println(resp)
- // }
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/UpdateWebACL
- func (c *WAFV2) UpdateWebACLRequest(input *UpdateWebACLInput) (req *request.Request, output *UpdateWebACLOutput) {
- op := &request.Operation{
- Name: opUpdateWebACL,
- HTTPMethod: "POST",
- HTTPPath: "/",
- }
- if input == nil {
- input = &UpdateWebACLInput{}
- }
- output = &UpdateWebACLOutput{}
- req = c.newRequest(op, input, output)
- return
- }
- // UpdateWebACL API operation for AWS WAFV2.
- //
- // Updates the specified WebACL. While updating a web ACL, WAF provides continuous
- // coverage to the resources that you have associated with the web ACL.
- //
- // This operation completely replaces the mutable specifications that you already
- // have for the web ACL with the ones that you provide to this call.
- //
- // To modify a web ACL, do the following:
- //
- // # Retrieve it by calling GetWebACL
- //
- // # Update its settings as needed
- //
- // # Provide the complete web ACL specification to this call
- //
- // When you make changes to web ACLs or web ACL components, like rules and rule
- // groups, WAF propagates the changes everywhere that the web ACL and its components
- // are stored and used. Your changes are applied within seconds, but there might
- // be a brief period of inconsistency when the changes have arrived in some
- // places and not in others. So, for example, if you change a rule action setting,
- // the action might be the old action in one area and the new action in another
- // area. Or if you add an IP address to an IP set used in a blocking rule, the
- // new address might briefly be blocked in one area while still allowed in another.
- // This temporary inconsistency can occur when you first associate a web ACL
- // with an Amazon Web Services resource and when you change a web ACL that is
- // already associated with a resource. Generally, any inconsistencies of this
- // type last only a few seconds.
- //
- // A web ACL defines a collection of rules to use to inspect and control web
- // requests. Each rule has an action defined (allow, block, or count) for requests
- // that match the statement of the rule. In the web ACL, you assign a default
- // action to take (allow, block) for any request that does not match any of
- // the rules. The rules in a web ACL can be a combination of the types Rule,
- // RuleGroup, and managed rule group. You can associate a web ACL with one or
- // more Amazon Web Services resources to protect. The resources can be an Amazon
- // CloudFront distribution, an Amazon API Gateway REST API, an Application Load
- // Balancer, an AppSync GraphQL API, or an Amazon Cognito user pool.
- //
- // Returns awserr.Error for service API and SDK errors. Use runtime type assertions
- // with awserr.Error's Code and Message methods to get detailed information about
- // the error.
- //
- // See the AWS API reference guide for AWS WAFV2's
- // API operation UpdateWebACL for usage and error information.
- //
- // Returned Error Types:
- //
- // - WAFInternalErrorException
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- //
- // - WAFInvalidParameterException
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- //
- // - WAFNonexistentItemException
- // WAF couldn’t perform the operation because your resource doesn't exist.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate.
- //
- // - WAFDuplicateItemException
- // WAF couldn’t perform the operation because the resource that you tried
- // to save is a duplicate of an existing one.
- //
- // - WAFOptimisticLockException
- // WAF couldn’t save your changes because you tried to update or delete a
- // resource that has changed since you last retrieved it. Get the resource again,
- // make any changes you need to make to the new copy, and retry your operation.
- //
- // - WAFLimitsExceededException
- // WAF couldn’t perform the operation because you exceeded your resource limit.
- // For example, the maximum number of WebACL objects that you can create for
- // an Amazon Web Services account. For more information, see WAF quotas (https://docs.aws.amazon.com/waf/latest/developerguide/limits.html)
- // in the WAF Developer Guide.
- //
- // - WAFInvalidResourceException
- // WAF couldn’t perform the operation because the resource that you requested
- // isn’t valid. Check the resource, and try again.
- //
- // - WAFUnavailableEntityException
- // WAF couldn’t retrieve a resource that you specified for this operation.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate. Verify the resources that you
- // are specifying in your request parameters and then retry the operation.
- //
- // - WAFSubscriptionNotFoundException
- // You tried to use a managed rule group that's available by subscription, but
- // you aren't subscribed to it yet.
- //
- // - WAFInvalidOperationException
- // The operation isn't valid.
- //
- // - WAFExpiredManagedRuleGroupVersionException
- // The operation failed because the specified version for the managed rule group
- // has expired. You can retrieve the available versions for the managed rule
- // group by calling ListAvailableManagedRuleGroupVersions.
- //
- // - WAFConfigurationWarningException
- // The operation failed because you are inspecting the web request body, headers,
- // or cookies without specifying how to handle oversize components. Rules that
- // inspect the body must either provide an OversizeHandling configuration or
- // they must be preceded by a SizeConstraintStatement that blocks the body content
- // from being too large. Rules that inspect the headers or cookies must provide
- // an OversizeHandling configuration.
- //
- // Provide the handling configuration and retry your operation.
- //
- // Alternately, you can suppress this warning by adding the following tag to
- // the resource that you provide to this operation: Tag (key:WAF:OversizeFieldsHandlingConstraintOptOut,
- // value:true).
- //
- // See also, https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/UpdateWebACL
- func (c *WAFV2) UpdateWebACL(input *UpdateWebACLInput) (*UpdateWebACLOutput, error) {
- req, out := c.UpdateWebACLRequest(input)
- return out, req.Send()
- }
- // UpdateWebACLWithContext is the same as UpdateWebACL with the addition of
- // the ability to pass a context and additional request options.
- //
- // See UpdateWebACL for details on how to use this API operation.
- //
- // The context must be non-nil and will be used for request cancellation. If
- // the context is nil a panic will occur. In the future the SDK may create
- // sub-contexts for http.Requests. See https://golang.org/pkg/context/
- // for more information on using Contexts.
- func (c *WAFV2) UpdateWebACLWithContext(ctx aws.Context, input *UpdateWebACLInput, opts ...request.Option) (*UpdateWebACLOutput, error) {
- req, out := c.UpdateWebACLRequest(input)
- req.SetContext(ctx)
- req.ApplyOptions(opts...)
- return out, req.Send()
- }
- // Details for your use of the Bot Control managed rule group, used in ManagedRuleGroupConfig.
- type AWSManagedRulesBotControlRuleSet struct {
- _ struct{} `type:"structure"`
- // The inspection level to use for the Bot Control rule group. The common level
- // is the least expensive. The targeted level includes all common level rules
- // and adds rules with more advanced inspection criteria. For details, see WAF
- // Bot Control rule group (https://docs.aws.amazon.com/waf/latest/developerguide/aws-managed-rule-groups-bot.html).
- //
- // InspectionLevel is a required field
- InspectionLevel *string `type:"string" required:"true" enum:"InspectionLevel"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s AWSManagedRulesBotControlRuleSet) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s AWSManagedRulesBotControlRuleSet) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *AWSManagedRulesBotControlRuleSet) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "AWSManagedRulesBotControlRuleSet"}
- if s.InspectionLevel == nil {
- invalidParams.Add(request.NewErrParamRequired("InspectionLevel"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetInspectionLevel sets the InspectionLevel field's value.
- func (s *AWSManagedRulesBotControlRuleSet) SetInspectionLevel(v string) *AWSManagedRulesBotControlRuleSet {
- s.InspectionLevel = &v
- return s
- }
- // A single action condition for a Condition in a logging filter.
- type ActionCondition struct {
- _ struct{} `type:"structure"`
- // The action setting that a log record must contain in order to meet the condition.
- // This is the action that WAF applied to the web request.
- //
- // For rule groups, this is either the configured rule action setting, or if
- // you've applied a rule action override to the rule, it's the override action.
- // The value EXCLUDED_AS_COUNT matches on excluded rules and also on rules that
- // have a rule action override of Count.
- //
- // Action is a required field
- Action *string `type:"string" required:"true" enum:"ActionValue"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ActionCondition) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ActionCondition) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ActionCondition) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ActionCondition"}
- if s.Action == nil {
- invalidParams.Add(request.NewErrParamRequired("Action"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetAction sets the Action field's value.
- func (s *ActionCondition) SetAction(v string) *ActionCondition {
- s.Action = &v
- return s
- }
- // Inspect all of the elements that WAF has parsed and extracted from the web
- // request component that you've identified in your FieldToMatch specifications.
- //
- // This is used only in the FieldToMatch specification for some web request
- // component types.
- //
- // JSON specification: "All": {}
- type All struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s All) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s All) GoString() string {
- return s.String()
- }
- // Inspect all query arguments of the web request.
- //
- // This is used only in the FieldToMatch specification for some web request
- // component types.
- //
- // JSON specification: "AllQueryArguments": {}
- type AllQueryArguments struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s AllQueryArguments) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s AllQueryArguments) GoString() string {
- return s.String()
- }
- // Specifies that WAF should allow the request and optionally defines additional
- // custom handling for the request.
- //
- // This is used in the context of other settings, for example to specify values
- // for RuleAction and web ACL DefaultAction.
- type AllowAction struct {
- _ struct{} `type:"structure"`
- // Defines custom handling for the web request.
- //
- // For information about customizing web requests and responses, see Customizing
- // web requests and responses in WAF (https://docs.aws.amazon.com/waf/latest/developerguide/waf-custom-request-response.html)
- // in the WAF Developer Guide (https://docs.aws.amazon.com/waf/latest/developerguide/waf-chapter.html).
- CustomRequestHandling *CustomRequestHandling `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s AllowAction) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s AllowAction) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *AllowAction) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "AllowAction"}
- if s.CustomRequestHandling != nil {
- if err := s.CustomRequestHandling.Validate(); err != nil {
- invalidParams.AddNested("CustomRequestHandling", err.(request.ErrInvalidParams))
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetCustomRequestHandling sets the CustomRequestHandling field's value.
- func (s *AllowAction) SetCustomRequestHandling(v *CustomRequestHandling) *AllowAction {
- s.CustomRequestHandling = v
- return s
- }
- // A logical rule statement used to combine other rule statements with AND logic.
- // You provide more than one Statement within the AndStatement.
- type AndStatement struct {
- _ struct{} `type:"structure"`
- // The statements to combine with AND logic. You can use any statements that
- // can be nested.
- //
- // Statements is a required field
- Statements []*Statement `type:"list" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s AndStatement) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s AndStatement) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *AndStatement) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "AndStatement"}
- if s.Statements == nil {
- invalidParams.Add(request.NewErrParamRequired("Statements"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetStatements sets the Statements field's value.
- func (s *AndStatement) SetStatements(v []*Statement) *AndStatement {
- s.Statements = v
- return s
- }
- type AssociateWebACLInput struct {
- _ struct{} `type:"structure"`
- // The Amazon Resource Name (ARN) of the resource to associate with the web
- // ACL.
- //
- // The ARN must be in one of the following formats:
- //
- // * For an Application Load Balancer: arn:aws:elasticloadbalancing:region:account-id:loadbalancer/app/load-balancer-name/load-balancer-id
- //
- // * For an Amazon API Gateway REST API: arn:aws:apigateway:region::/restapis/api-id/stages/stage-name
- //
- // * For an AppSync GraphQL API: arn:aws:appsync:region:account-id:apis/GraphQLApiId
- //
- // * For an Amazon Cognito user pool: arn:aws:cognito-idp:region:account-id:userpool/user-pool-id
- //
- // ResourceArn is a required field
- ResourceArn *string `min:"20" type:"string" required:"true"`
- // The Amazon Resource Name (ARN) of the web ACL that you want to associate
- // with the resource.
- //
- // WebACLArn is a required field
- WebACLArn *string `min:"20" type:"string" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s AssociateWebACLInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s AssociateWebACLInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *AssociateWebACLInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "AssociateWebACLInput"}
- if s.ResourceArn == nil {
- invalidParams.Add(request.NewErrParamRequired("ResourceArn"))
- }
- if s.ResourceArn != nil && len(*s.ResourceArn) < 20 {
- invalidParams.Add(request.NewErrParamMinLen("ResourceArn", 20))
- }
- if s.WebACLArn == nil {
- invalidParams.Add(request.NewErrParamRequired("WebACLArn"))
- }
- if s.WebACLArn != nil && len(*s.WebACLArn) < 20 {
- invalidParams.Add(request.NewErrParamMinLen("WebACLArn", 20))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetResourceArn sets the ResourceArn field's value.
- func (s *AssociateWebACLInput) SetResourceArn(v string) *AssociateWebACLInput {
- s.ResourceArn = &v
- return s
- }
- // SetWebACLArn sets the WebACLArn field's value.
- func (s *AssociateWebACLInput) SetWebACLArn(v string) *AssociateWebACLInput {
- s.WebACLArn = &v
- return s
- }
- type AssociateWebACLOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s AssociateWebACLOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s AssociateWebACLOutput) GoString() string {
- return s.String()
- }
- // Specifies that WAF should block the request and optionally defines additional
- // custom handling for the response to the web request.
- //
- // This is used in the context of other settings, for example to specify values
- // for RuleAction and web ACL DefaultAction.
- type BlockAction struct {
- _ struct{} `type:"structure"`
- // Defines a custom response for the web request.
- //
- // For information about customizing web requests and responses, see Customizing
- // web requests and responses in WAF (https://docs.aws.amazon.com/waf/latest/developerguide/waf-custom-request-response.html)
- // in the WAF Developer Guide (https://docs.aws.amazon.com/waf/latest/developerguide/waf-chapter.html).
- CustomResponse *CustomResponse `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s BlockAction) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s BlockAction) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *BlockAction) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "BlockAction"}
- if s.CustomResponse != nil {
- if err := s.CustomResponse.Validate(); err != nil {
- invalidParams.AddNested("CustomResponse", err.(request.ErrInvalidParams))
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetCustomResponse sets the CustomResponse field's value.
- func (s *BlockAction) SetCustomResponse(v *CustomResponse) *BlockAction {
- s.CustomResponse = v
- return s
- }
- // Inspect the body of the web request. The body immediately follows the request
- // headers.
- //
- // This is used to indicate the web request component to inspect, in the FieldToMatch
- // specification.
- type Body struct {
- _ struct{} `type:"structure"`
- // What WAF should do if the body is larger than WAF can inspect. WAF does not
- // support inspecting the entire contents of the body of a web request when
- // the body exceeds 8 KB (8192 bytes). Only the first 8 KB of the request body
- // are forwarded to WAF by the underlying host service.
- //
- // The options for oversize handling are the following:
- //
- // * CONTINUE - Inspect the body normally, according to the rule inspection
- // criteria.
- //
- // * MATCH - Treat the web request as matching the rule statement. WAF applies
- // the rule action to the request.
- //
- // * NO_MATCH - Treat the web request as not matching the rule statement.
- //
- // You can combine the MATCH or NO_MATCH settings for oversize handling with
- // your rule and web ACL action settings, so that you block any request whose
- // body is over 8 KB.
- //
- // Default: CONTINUE
- OversizeHandling *string `type:"string" enum:"OversizeHandling"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s Body) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s Body) GoString() string {
- return s.String()
- }
- // SetOversizeHandling sets the OversizeHandling field's value.
- func (s *Body) SetOversizeHandling(v string) *Body {
- s.OversizeHandling = &v
- return s
- }
- // A rule statement that defines a string match search for WAF to apply to web
- // requests. The byte match statement provides the bytes to search for, the
- // location in requests that you want WAF to search, and other settings. The
- // bytes to search for are typically a string that corresponds with ASCII characters.
- // In the WAF console and the developer guide, this is called a string match
- // statement.
- type ByteMatchStatement struct {
- _ struct{} `type:"structure"`
- // The part of the web request that you want WAF to inspect.
- //
- // FieldToMatch is a required field
- FieldToMatch *FieldToMatch `type:"structure" required:"true"`
- // The area within the portion of the web request that you want WAF to search
- // for SearchString. Valid values include the following:
- //
- // CONTAINS
- //
- // The specified part of the web request must include the value of SearchString,
- // but the location doesn't matter.
- //
- // CONTAINS_WORD
- //
- // The specified part of the web request must include the value of SearchString,
- // and SearchString must contain only alphanumeric characters or underscore
- // (A-Z, a-z, 0-9, or _). In addition, SearchString must be a word, which means
- // that both of the following are true:
- //
- // * SearchString is at the beginning of the specified part of the web request
- // or is preceded by a character other than an alphanumeric character or
- // underscore (_). Examples include the value of a header and ;BadBot.
- //
- // * SearchString is at the end of the specified part of the web request
- // or is followed by a character other than an alphanumeric character or
- // underscore (_), for example, BadBot; and -BadBot;.
- //
- // EXACTLY
- //
- // The value of the specified part of the web request must exactly match the
- // value of SearchString.
- //
- // STARTS_WITH
- //
- // The value of SearchString must appear at the beginning of the specified part
- // of the web request.
- //
- // ENDS_WITH
- //
- // The value of SearchString must appear at the end of the specified part of
- // the web request.
- //
- // PositionalConstraint is a required field
- PositionalConstraint *string `type:"string" required:"true" enum:"PositionalConstraint"`
- // A string value that you want WAF to search for. WAF searches only in the
- // part of web requests that you designate for inspection in FieldToMatch. The
- // maximum length of the value is 50 bytes.
- //
- // Valid values depend on the component that you specify for inspection in FieldToMatch:
- //
- // * Method: The HTTP method that you want WAF to search for. This indicates
- // the type of operation specified in the request.
- //
- // * UriPath: The value that you want WAF to search for in the URI path,
- // for example, /images/daily-ad.jpg.
- //
- // If SearchString includes alphabetic characters A-Z and a-z, note that the
- // value is case sensitive.
- //
- // If you're using the WAF API
- //
- // Specify a base64-encoded version of the value. The maximum length of the
- // value before you base64-encode it is 50 bytes.
- //
- // For example, suppose the value of Type is HEADER and the value of Data is
- // User-Agent. If you want to search the User-Agent header for the value BadBot,
- // you base64-encode BadBot using MIME base64-encoding and include the resulting
- // value, QmFkQm90, in the value of SearchString.
- //
- // If you're using the CLI or one of the Amazon Web Services SDKs
- //
- // The value that you want WAF to search for. The SDK automatically base64 encodes
- // the value.
- // SearchString is automatically base64 encoded/decoded by the SDK.
- //
- // SearchString is a required field
- SearchString []byte `type:"blob" required:"true"`
- // Text transformations eliminate some of the unusual formatting that attackers
- // use in web requests in an effort to bypass detection. If you specify one
- // or more transformations in a rule statement, WAF performs all transformations
- // on the content of the request component identified by FieldToMatch, starting
- // from the lowest priority setting, before inspecting the content for a match.
- //
- // TextTransformations is a required field
- TextTransformations []*TextTransformation `min:"1" type:"list" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ByteMatchStatement) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ByteMatchStatement) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ByteMatchStatement) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ByteMatchStatement"}
- if s.FieldToMatch == nil {
- invalidParams.Add(request.NewErrParamRequired("FieldToMatch"))
- }
- if s.PositionalConstraint == nil {
- invalidParams.Add(request.NewErrParamRequired("PositionalConstraint"))
- }
- if s.SearchString == nil {
- invalidParams.Add(request.NewErrParamRequired("SearchString"))
- }
- if s.TextTransformations == nil {
- invalidParams.Add(request.NewErrParamRequired("TextTransformations"))
- }
- if s.TextTransformations != nil && len(s.TextTransformations) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("TextTransformations", 1))
- }
- if s.FieldToMatch != nil {
- if err := s.FieldToMatch.Validate(); err != nil {
- invalidParams.AddNested("FieldToMatch", err.(request.ErrInvalidParams))
- }
- }
- if s.TextTransformations != nil {
- for i, v := range s.TextTransformations {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "TextTransformations", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetFieldToMatch sets the FieldToMatch field's value.
- func (s *ByteMatchStatement) SetFieldToMatch(v *FieldToMatch) *ByteMatchStatement {
- s.FieldToMatch = v
- return s
- }
- // SetPositionalConstraint sets the PositionalConstraint field's value.
- func (s *ByteMatchStatement) SetPositionalConstraint(v string) *ByteMatchStatement {
- s.PositionalConstraint = &v
- return s
- }
- // SetSearchString sets the SearchString field's value.
- func (s *ByteMatchStatement) SetSearchString(v []byte) *ByteMatchStatement {
- s.SearchString = v
- return s
- }
- // SetTextTransformations sets the TextTransformations field's value.
- func (s *ByteMatchStatement) SetTextTransformations(v []*TextTransformation) *ByteMatchStatement {
- s.TextTransformations = v
- return s
- }
- // Specifies that WAF should run a CAPTCHA check against the request:
- //
- // - If the request includes a valid, unexpired CAPTCHA token, WAF applies
- // any custom request handling and labels that you've configured and then
- // allows the web request inspection to proceed to the next rule, similar
- // to a CountAction.
- //
- // - If the request doesn't include a valid, unexpired token, WAF discontinues
- // the web ACL evaluation of the request and blocks it from going to its
- // intended destination. WAF generates a response that it sends back to the
- // client, which includes the following: The header x-amzn-waf-action with
- // a value of captcha. The HTTP status code 405 Method Not Allowed. If the
- // request contains an Accept header with a value of text/html, the response
- // includes a CAPTCHA JavaScript page interstitial.
- //
- // You can configure the expiration time in the CaptchaConfig ImmunityTimeProperty
- // setting at the rule and web ACL level. The rule setting overrides the web
- // ACL setting.
- //
- // This action option is available for rules. It isn't available for web ACL
- // default actions.
- type CaptchaAction struct {
- _ struct{} `type:"structure"`
- // Defines custom handling for the web request, used when the CAPTCHA inspection
- // determines that the request's token is valid and unexpired.
- //
- // For information about customizing web requests and responses, see Customizing
- // web requests and responses in WAF (https://docs.aws.amazon.com/waf/latest/developerguide/waf-custom-request-response.html)
- // in the WAF Developer Guide (https://docs.aws.amazon.com/waf/latest/developerguide/waf-chapter.html).
- CustomRequestHandling *CustomRequestHandling `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s CaptchaAction) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s CaptchaAction) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CaptchaAction) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CaptchaAction"}
- if s.CustomRequestHandling != nil {
- if err := s.CustomRequestHandling.Validate(); err != nil {
- invalidParams.AddNested("CustomRequestHandling", err.(request.ErrInvalidParams))
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetCustomRequestHandling sets the CustomRequestHandling field's value.
- func (s *CaptchaAction) SetCustomRequestHandling(v *CustomRequestHandling) *CaptchaAction {
- s.CustomRequestHandling = v
- return s
- }
- // Specifies how WAF should handle CAPTCHA evaluations. This is available at
- // the web ACL level and in each rule.
- type CaptchaConfig struct {
- _ struct{} `type:"structure"`
- // Determines how long a CAPTCHA timestamp in the token remains valid after
- // the client successfully solves a CAPTCHA puzzle.
- ImmunityTimeProperty *ImmunityTimeProperty `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s CaptchaConfig) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s CaptchaConfig) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CaptchaConfig) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CaptchaConfig"}
- if s.ImmunityTimeProperty != nil {
- if err := s.ImmunityTimeProperty.Validate(); err != nil {
- invalidParams.AddNested("ImmunityTimeProperty", err.(request.ErrInvalidParams))
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetImmunityTimeProperty sets the ImmunityTimeProperty field's value.
- func (s *CaptchaConfig) SetImmunityTimeProperty(v *ImmunityTimeProperty) *CaptchaConfig {
- s.ImmunityTimeProperty = v
- return s
- }
- // The result from the inspection of the web request for a valid CAPTCHA token.
- type CaptchaResponse struct {
- _ struct{} `type:"structure"`
- // The reason for failure, populated when the evaluation of the token fails.
- FailureReason *string `type:"string" enum:"FailureReason"`
- // The HTTP response code indicating the status of the CAPTCHA token in the
- // web request. If the token is missing, invalid, or expired, this code is 405
- // Method Not Allowed.
- ResponseCode *int64 `type:"integer"`
- // The time that the CAPTCHA was last solved for the supplied token.
- SolveTimestamp *int64 `type:"long"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s CaptchaResponse) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s CaptchaResponse) GoString() string {
- return s.String()
- }
- // SetFailureReason sets the FailureReason field's value.
- func (s *CaptchaResponse) SetFailureReason(v string) *CaptchaResponse {
- s.FailureReason = &v
- return s
- }
- // SetResponseCode sets the ResponseCode field's value.
- func (s *CaptchaResponse) SetResponseCode(v int64) *CaptchaResponse {
- s.ResponseCode = &v
- return s
- }
- // SetSolveTimestamp sets the SolveTimestamp field's value.
- func (s *CaptchaResponse) SetSolveTimestamp(v int64) *CaptchaResponse {
- s.SolveTimestamp = &v
- return s
- }
- // Specifies that WAF should run a Challenge check against the request to verify
- // that the request is coming from a legitimate client session:
- //
- // - If the request includes a valid, unexpired challenge token, WAF applies
- // any custom request handling and labels that you've configured and then
- // allows the web request inspection to proceed to the next rule, similar
- // to a CountAction.
- //
- // - If the request doesn't include a valid, unexpired challenge token, WAF
- // discontinues the web ACL evaluation of the request and blocks it from
- // going to its intended destination. WAF then generates a challenge response
- // that it sends back to the client, which includes the following: The header
- // x-amzn-waf-action with a value of challenge. The HTTP status code 202
- // Request Accepted. If the request contains an Accept header with a value
- // of text/html, the response includes a JavaScript page interstitial with
- // a challenge script. Challenges run silent browser interrogations in the
- // background, and don't generally affect the end user experience. A challenge
- // enforces token acquisition using an interstitial JavaScript challenge
- // that inspects the client session for legitimate behavior. The challenge
- // blocks bots or at least increases the cost of operating sophisticated
- // bots. After the client session successfully responds to the challenge,
- // it receives a new token from WAF, which the challenge script uses to resubmit
- // the original request.
- //
- // You can configure the expiration time in the ChallengeConfig ImmunityTimeProperty
- // setting at the rule and web ACL level. The rule setting overrides the web
- // ACL setting.
- //
- // This action option is available for rules. It isn't available for web ACL
- // default actions.
- type ChallengeAction struct {
- _ struct{} `type:"structure"`
- // Defines custom handling for the web request, used when the challenge inspection
- // determines that the request's token is valid and unexpired.
- //
- // For information about customizing web requests and responses, see Customizing
- // web requests and responses in WAF (https://docs.aws.amazon.com/waf/latest/developerguide/waf-custom-request-response.html)
- // in the WAF Developer Guide (https://docs.aws.amazon.com/waf/latest/developerguide/waf-chapter.html).
- CustomRequestHandling *CustomRequestHandling `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ChallengeAction) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ChallengeAction) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ChallengeAction) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ChallengeAction"}
- if s.CustomRequestHandling != nil {
- if err := s.CustomRequestHandling.Validate(); err != nil {
- invalidParams.AddNested("CustomRequestHandling", err.(request.ErrInvalidParams))
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetCustomRequestHandling sets the CustomRequestHandling field's value.
- func (s *ChallengeAction) SetCustomRequestHandling(v *CustomRequestHandling) *ChallengeAction {
- s.CustomRequestHandling = v
- return s
- }
- // Specifies how WAF should handle Challenge evaluations. This is available
- // at the web ACL level and in each rule.
- type ChallengeConfig struct {
- _ struct{} `type:"structure"`
- // Determines how long a challenge timestamp in the token remains valid after
- // the client successfully responds to a challenge.
- ImmunityTimeProperty *ImmunityTimeProperty `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ChallengeConfig) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ChallengeConfig) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ChallengeConfig) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ChallengeConfig"}
- if s.ImmunityTimeProperty != nil {
- if err := s.ImmunityTimeProperty.Validate(); err != nil {
- invalidParams.AddNested("ImmunityTimeProperty", err.(request.ErrInvalidParams))
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetImmunityTimeProperty sets the ImmunityTimeProperty field's value.
- func (s *ChallengeConfig) SetImmunityTimeProperty(v *ImmunityTimeProperty) *ChallengeConfig {
- s.ImmunityTimeProperty = v
- return s
- }
- // The result from the inspection of the web request for a valid challenge token.
- type ChallengeResponse struct {
- _ struct{} `type:"structure"`
- // The reason for failure, populated when the evaluation of the token fails.
- FailureReason *string `type:"string" enum:"FailureReason"`
- // The HTTP response code indicating the status of the challenge token in the
- // web request. If the token is missing, invalid, or expired, this code is 202
- // Request Accepted.
- ResponseCode *int64 `type:"integer"`
- // The time that the challenge was last solved for the supplied token.
- SolveTimestamp *int64 `type:"long"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ChallengeResponse) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ChallengeResponse) GoString() string {
- return s.String()
- }
- // SetFailureReason sets the FailureReason field's value.
- func (s *ChallengeResponse) SetFailureReason(v string) *ChallengeResponse {
- s.FailureReason = &v
- return s
- }
- // SetResponseCode sets the ResponseCode field's value.
- func (s *ChallengeResponse) SetResponseCode(v int64) *ChallengeResponse {
- s.ResponseCode = &v
- return s
- }
- // SetSolveTimestamp sets the SolveTimestamp field's value.
- func (s *ChallengeResponse) SetSolveTimestamp(v int64) *ChallengeResponse {
- s.SolveTimestamp = &v
- return s
- }
- type CheckCapacityInput struct {
- _ struct{} `type:"structure"`
- // An array of Rule that you're configuring to use in a rule group or web ACL.
- //
- // Rules is a required field
- Rules []*Rule `type:"list" required:"true"`
- // Specifies whether this is for an Amazon CloudFront distribution or for a
- // regional application. A regional application can be an Application Load Balancer
- // (ALB), an Amazon API Gateway REST API, an AppSync GraphQL API, or an Amazon
- // Cognito user pool.
- //
- // To work with CloudFront, you must also specify the Region US East (N. Virginia)
- // as follows:
- //
- // * CLI - Specify the Region when you use the CloudFront scope: --scope=CLOUDFRONT
- // --region=us-east-1.
- //
- // * API and SDKs - For all calls, use the Region endpoint us-east-1.
- //
- // Scope is a required field
- Scope *string `type:"string" required:"true" enum:"Scope"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s CheckCapacityInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s CheckCapacityInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CheckCapacityInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CheckCapacityInput"}
- if s.Rules == nil {
- invalidParams.Add(request.NewErrParamRequired("Rules"))
- }
- if s.Scope == nil {
- invalidParams.Add(request.NewErrParamRequired("Scope"))
- }
- if s.Rules != nil {
- for i, v := range s.Rules {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "Rules", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetRules sets the Rules field's value.
- func (s *CheckCapacityInput) SetRules(v []*Rule) *CheckCapacityInput {
- s.Rules = v
- return s
- }
- // SetScope sets the Scope field's value.
- func (s *CheckCapacityInput) SetScope(v string) *CheckCapacityInput {
- s.Scope = &v
- return s
- }
- type CheckCapacityOutput struct {
- _ struct{} `type:"structure"`
- // The capacity required by the rules and scope.
- Capacity *int64 `type:"long"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s CheckCapacityOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s CheckCapacityOutput) GoString() string {
- return s.String()
- }
- // SetCapacity sets the Capacity field's value.
- func (s *CheckCapacityOutput) SetCapacity(v int64) *CheckCapacityOutput {
- s.Capacity = &v
- return s
- }
- // A single match condition for a Filter.
- type Condition struct {
- _ struct{} `type:"structure"`
- // A single action condition. This is the action setting that a log record must
- // contain in order to meet the condition.
- ActionCondition *ActionCondition `type:"structure"`
- // A single label name condition. This is the fully qualified label name that
- // a log record must contain in order to meet the condition. Fully qualified
- // labels have a prefix, optional namespaces, and label name. The prefix identifies
- // the rule group or web ACL context of the rule that added the label.
- LabelNameCondition *LabelNameCondition `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s Condition) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s Condition) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *Condition) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "Condition"}
- if s.ActionCondition != nil {
- if err := s.ActionCondition.Validate(); err != nil {
- invalidParams.AddNested("ActionCondition", err.(request.ErrInvalidParams))
- }
- }
- if s.LabelNameCondition != nil {
- if err := s.LabelNameCondition.Validate(); err != nil {
- invalidParams.AddNested("LabelNameCondition", err.(request.ErrInvalidParams))
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetActionCondition sets the ActionCondition field's value.
- func (s *Condition) SetActionCondition(v *ActionCondition) *Condition {
- s.ActionCondition = v
- return s
- }
- // SetLabelNameCondition sets the LabelNameCondition field's value.
- func (s *Condition) SetLabelNameCondition(v *LabelNameCondition) *Condition {
- s.LabelNameCondition = v
- return s
- }
- // The filter to use to identify the subset of cookies to inspect in a web request.
- //
- // You must specify exactly one setting: either All, IncludedCookies, or ExcludedCookies.
- //
- // Example JSON: "MatchPattern": { "IncludedCookies": {"KeyToInclude1", "KeyToInclude2",
- // "KeyToInclude3"} }
- type CookieMatchPattern struct {
- _ struct{} `type:"structure"`
- // Inspect all cookies.
- All *All `type:"structure"`
- // Inspect only the cookies whose keys don't match any of the strings specified
- // here.
- ExcludedCookies []*string `min:"1" type:"list"`
- // Inspect only the cookies that have a key that matches one of the strings
- // specified here.
- IncludedCookies []*string `min:"1" type:"list"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s CookieMatchPattern) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s CookieMatchPattern) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CookieMatchPattern) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CookieMatchPattern"}
- if s.ExcludedCookies != nil && len(s.ExcludedCookies) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("ExcludedCookies", 1))
- }
- if s.IncludedCookies != nil && len(s.IncludedCookies) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("IncludedCookies", 1))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetAll sets the All field's value.
- func (s *CookieMatchPattern) SetAll(v *All) *CookieMatchPattern {
- s.All = v
- return s
- }
- // SetExcludedCookies sets the ExcludedCookies field's value.
- func (s *CookieMatchPattern) SetExcludedCookies(v []*string) *CookieMatchPattern {
- s.ExcludedCookies = v
- return s
- }
- // SetIncludedCookies sets the IncludedCookies field's value.
- func (s *CookieMatchPattern) SetIncludedCookies(v []*string) *CookieMatchPattern {
- s.IncludedCookies = v
- return s
- }
- // Inspect the cookies in the web request. You can specify the parts of the
- // cookies to inspect and you can narrow the set of cookies to inspect by including
- // or excluding specific keys.
- //
- // This is used to indicate the web request component to inspect, in the FieldToMatch
- // specification.
- //
- // Example JSON: "Cookies": { "MatchPattern": { "All": {} }, "MatchScope": "KEY",
- // "OversizeHandling": "MATCH" }
- type Cookies struct {
- _ struct{} `type:"structure"`
- // The filter to use to identify the subset of cookies to inspect in a web request.
- //
- // You must specify exactly one setting: either All, IncludedCookies, or ExcludedCookies.
- //
- // Example JSON: "MatchPattern": { "IncludedCookies": {"KeyToInclude1", "KeyToInclude2",
- // "KeyToInclude3"} }
- //
- // MatchPattern is a required field
- MatchPattern *CookieMatchPattern `type:"structure" required:"true"`
- // The parts of the cookies to inspect with the rule inspection criteria. If
- // you specify All, WAF inspects both keys and values.
- //
- // MatchScope is a required field
- MatchScope *string `type:"string" required:"true" enum:"MapMatchScope"`
- // What WAF should do if the cookies of the request are larger than WAF can
- // inspect. WAF does not support inspecting the entire contents of request cookies
- // when they exceed 8 KB (8192 bytes) or 200 total cookies. The underlying host
- // service forwards a maximum of 200 cookies and at most 8 KB of cookie contents
- // to WAF.
- //
- // The options for oversize handling are the following:
- //
- // * CONTINUE - Inspect the cookies normally, according to the rule inspection
- // criteria.
- //
- // * MATCH - Treat the web request as matching the rule statement. WAF applies
- // the rule action to the request.
- //
- // * NO_MATCH - Treat the web request as not matching the rule statement.
- //
- // OversizeHandling is a required field
- OversizeHandling *string `type:"string" required:"true" enum:"OversizeHandling"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s Cookies) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s Cookies) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *Cookies) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "Cookies"}
- if s.MatchPattern == nil {
- invalidParams.Add(request.NewErrParamRequired("MatchPattern"))
- }
- if s.MatchScope == nil {
- invalidParams.Add(request.NewErrParamRequired("MatchScope"))
- }
- if s.OversizeHandling == nil {
- invalidParams.Add(request.NewErrParamRequired("OversizeHandling"))
- }
- if s.MatchPattern != nil {
- if err := s.MatchPattern.Validate(); err != nil {
- invalidParams.AddNested("MatchPattern", err.(request.ErrInvalidParams))
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetMatchPattern sets the MatchPattern field's value.
- func (s *Cookies) SetMatchPattern(v *CookieMatchPattern) *Cookies {
- s.MatchPattern = v
- return s
- }
- // SetMatchScope sets the MatchScope field's value.
- func (s *Cookies) SetMatchScope(v string) *Cookies {
- s.MatchScope = &v
- return s
- }
- // SetOversizeHandling sets the OversizeHandling field's value.
- func (s *Cookies) SetOversizeHandling(v string) *Cookies {
- s.OversizeHandling = &v
- return s
- }
- // Specifies that WAF should count the request. Optionally defines additional
- // custom handling for the request.
- //
- // This is used in the context of other settings, for example to specify values
- // for RuleAction and web ACL DefaultAction.
- type CountAction struct {
- _ struct{} `type:"structure"`
- // Defines custom handling for the web request.
- //
- // For information about customizing web requests and responses, see Customizing
- // web requests and responses in WAF (https://docs.aws.amazon.com/waf/latest/developerguide/waf-custom-request-response.html)
- // in the WAF Developer Guide (https://docs.aws.amazon.com/waf/latest/developerguide/waf-chapter.html).
- CustomRequestHandling *CustomRequestHandling `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s CountAction) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s CountAction) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CountAction) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CountAction"}
- if s.CustomRequestHandling != nil {
- if err := s.CustomRequestHandling.Validate(); err != nil {
- invalidParams.AddNested("CustomRequestHandling", err.(request.ErrInvalidParams))
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetCustomRequestHandling sets the CustomRequestHandling field's value.
- func (s *CountAction) SetCustomRequestHandling(v *CustomRequestHandling) *CountAction {
- s.CustomRequestHandling = v
- return s
- }
- type CreateIPSetInput struct {
- _ struct{} `type:"structure"`
- // Contains an array of strings that specifies zero or more IP addresses or
- // blocks of IP addresses. All addresses must be specified using Classless Inter-Domain
- // Routing (CIDR) notation. WAF supports all IPv4 and IPv6 CIDR ranges except
- // for /0.
- //
- // Example address strings:
- //
- // * To configure WAF to allow, block, or count requests that originated
- // from the IP address 192.0.2.44, specify 192.0.2.44/32.
- //
- // * To configure WAF to allow, block, or count requests that originated
- // from IP addresses from 192.0.2.0 to 192.0.2.255, specify 192.0.2.0/24.
- //
- // * To configure WAF to allow, block, or count requests that originated
- // from the IP address 1111:0000:0000:0000:0000:0000:0000:0111, specify 1111:0000:0000:0000:0000:0000:0000:0111/128.
- //
- // * To configure WAF to allow, block, or count requests that originated
- // from IP addresses 1111:0000:0000:0000:0000:0000:0000:0000 to 1111:0000:0000:0000:ffff:ffff:ffff:ffff,
- // specify 1111:0000:0000:0000:0000:0000:0000:0000/64.
- //
- // For more information about CIDR notation, see the Wikipedia entry Classless
- // Inter-Domain Routing (https://en.wikipedia.org/wiki/Classless_Inter-Domain_Routing).
- //
- // Example JSON Addresses specifications:
- //
- // * Empty array: "Addresses": []
- //
- // * Array with one address: "Addresses": ["192.0.2.44/32"]
- //
- // * Array with three addresses: "Addresses": ["192.0.2.44/32", "192.0.2.0/24",
- // "192.0.0.0/16"]
- //
- // * INVALID specification: "Addresses": [""] INVALID
- //
- // Addresses is a required field
- Addresses []*string `type:"list" required:"true"`
- // A description of the IP set that helps with identification.
- Description *string `min:"1" type:"string"`
- // The version of the IP addresses, either IPV4 or IPV6.
- //
- // IPAddressVersion is a required field
- IPAddressVersion *string `type:"string" required:"true" enum:"IPAddressVersion"`
- // The name of the IP set. You cannot change the name of an IPSet after you
- // create it.
- //
- // Name is a required field
- Name *string `min:"1" type:"string" required:"true"`
- // Specifies whether this is for an Amazon CloudFront distribution or for a
- // regional application. A regional application can be an Application Load Balancer
- // (ALB), an Amazon API Gateway REST API, an AppSync GraphQL API, or an Amazon
- // Cognito user pool.
- //
- // To work with CloudFront, you must also specify the Region US East (N. Virginia)
- // as follows:
- //
- // * CLI - Specify the Region when you use the CloudFront scope: --scope=CLOUDFRONT
- // --region=us-east-1.
- //
- // * API and SDKs - For all calls, use the Region endpoint us-east-1.
- //
- // Scope is a required field
- Scope *string `type:"string" required:"true" enum:"Scope"`
- // An array of key:value pairs to associate with the resource.
- Tags []*Tag `min:"1" type:"list"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s CreateIPSetInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s CreateIPSetInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CreateIPSetInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CreateIPSetInput"}
- if s.Addresses == nil {
- invalidParams.Add(request.NewErrParamRequired("Addresses"))
- }
- if s.Description != nil && len(*s.Description) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Description", 1))
- }
- if s.IPAddressVersion == nil {
- invalidParams.Add(request.NewErrParamRequired("IPAddressVersion"))
- }
- if s.Name == nil {
- invalidParams.Add(request.NewErrParamRequired("Name"))
- }
- if s.Name != nil && len(*s.Name) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Name", 1))
- }
- if s.Scope == nil {
- invalidParams.Add(request.NewErrParamRequired("Scope"))
- }
- if s.Tags != nil && len(s.Tags) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Tags", 1))
- }
- if s.Tags != nil {
- for i, v := range s.Tags {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "Tags", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetAddresses sets the Addresses field's value.
- func (s *CreateIPSetInput) SetAddresses(v []*string) *CreateIPSetInput {
- s.Addresses = v
- return s
- }
- // SetDescription sets the Description field's value.
- func (s *CreateIPSetInput) SetDescription(v string) *CreateIPSetInput {
- s.Description = &v
- return s
- }
- // SetIPAddressVersion sets the IPAddressVersion field's value.
- func (s *CreateIPSetInput) SetIPAddressVersion(v string) *CreateIPSetInput {
- s.IPAddressVersion = &v
- return s
- }
- // SetName sets the Name field's value.
- func (s *CreateIPSetInput) SetName(v string) *CreateIPSetInput {
- s.Name = &v
- return s
- }
- // SetScope sets the Scope field's value.
- func (s *CreateIPSetInput) SetScope(v string) *CreateIPSetInput {
- s.Scope = &v
- return s
- }
- // SetTags sets the Tags field's value.
- func (s *CreateIPSetInput) SetTags(v []*Tag) *CreateIPSetInput {
- s.Tags = v
- return s
- }
- type CreateIPSetOutput struct {
- _ struct{} `type:"structure"`
- // High-level information about an IPSet, returned by operations like create
- // and list. This provides information like the ID, that you can use to retrieve
- // and manage an IPSet, and the ARN, that you provide to the IPSetReferenceStatement
- // to use the address set in a Rule.
- Summary *IPSetSummary `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s CreateIPSetOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s CreateIPSetOutput) GoString() string {
- return s.String()
- }
- // SetSummary sets the Summary field's value.
- func (s *CreateIPSetOutput) SetSummary(v *IPSetSummary) *CreateIPSetOutput {
- s.Summary = v
- return s
- }
- type CreateRegexPatternSetInput struct {
- _ struct{} `type:"structure"`
- // A description of the set that helps with identification.
- Description *string `min:"1" type:"string"`
- // The name of the set. You cannot change the name after you create the set.
- //
- // Name is a required field
- Name *string `min:"1" type:"string" required:"true"`
- // Array of regular expression strings.
- //
- // RegularExpressionList is a required field
- RegularExpressionList []*Regex `type:"list" required:"true"`
- // Specifies whether this is for an Amazon CloudFront distribution or for a
- // regional application. A regional application can be an Application Load Balancer
- // (ALB), an Amazon API Gateway REST API, an AppSync GraphQL API, or an Amazon
- // Cognito user pool.
- //
- // To work with CloudFront, you must also specify the Region US East (N. Virginia)
- // as follows:
- //
- // * CLI - Specify the Region when you use the CloudFront scope: --scope=CLOUDFRONT
- // --region=us-east-1.
- //
- // * API and SDKs - For all calls, use the Region endpoint us-east-1.
- //
- // Scope is a required field
- Scope *string `type:"string" required:"true" enum:"Scope"`
- // An array of key:value pairs to associate with the resource.
- Tags []*Tag `min:"1" type:"list"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s CreateRegexPatternSetInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s CreateRegexPatternSetInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CreateRegexPatternSetInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CreateRegexPatternSetInput"}
- if s.Description != nil && len(*s.Description) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Description", 1))
- }
- if s.Name == nil {
- invalidParams.Add(request.NewErrParamRequired("Name"))
- }
- if s.Name != nil && len(*s.Name) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Name", 1))
- }
- if s.RegularExpressionList == nil {
- invalidParams.Add(request.NewErrParamRequired("RegularExpressionList"))
- }
- if s.Scope == nil {
- invalidParams.Add(request.NewErrParamRequired("Scope"))
- }
- if s.Tags != nil && len(s.Tags) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Tags", 1))
- }
- if s.RegularExpressionList != nil {
- for i, v := range s.RegularExpressionList {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "RegularExpressionList", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if s.Tags != nil {
- for i, v := range s.Tags {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "Tags", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetDescription sets the Description field's value.
- func (s *CreateRegexPatternSetInput) SetDescription(v string) *CreateRegexPatternSetInput {
- s.Description = &v
- return s
- }
- // SetName sets the Name field's value.
- func (s *CreateRegexPatternSetInput) SetName(v string) *CreateRegexPatternSetInput {
- s.Name = &v
- return s
- }
- // SetRegularExpressionList sets the RegularExpressionList field's value.
- func (s *CreateRegexPatternSetInput) SetRegularExpressionList(v []*Regex) *CreateRegexPatternSetInput {
- s.RegularExpressionList = v
- return s
- }
- // SetScope sets the Scope field's value.
- func (s *CreateRegexPatternSetInput) SetScope(v string) *CreateRegexPatternSetInput {
- s.Scope = &v
- return s
- }
- // SetTags sets the Tags field's value.
- func (s *CreateRegexPatternSetInput) SetTags(v []*Tag) *CreateRegexPatternSetInput {
- s.Tags = v
- return s
- }
- type CreateRegexPatternSetOutput struct {
- _ struct{} `type:"structure"`
- // High-level information about a RegexPatternSet, returned by operations like
- // create and list. This provides information like the ID, that you can use
- // to retrieve and manage a RegexPatternSet, and the ARN, that you provide to
- // the RegexPatternSetReferenceStatement to use the pattern set in a Rule.
- Summary *RegexPatternSetSummary `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s CreateRegexPatternSetOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s CreateRegexPatternSetOutput) GoString() string {
- return s.String()
- }
- // SetSummary sets the Summary field's value.
- func (s *CreateRegexPatternSetOutput) SetSummary(v *RegexPatternSetSummary) *CreateRegexPatternSetOutput {
- s.Summary = v
- return s
- }
- type CreateRuleGroupInput struct {
- _ struct{} `type:"structure"`
- // The web ACL capacity units (WCUs) required for this rule group.
- //
- // When you create your own rule group, you define this, and you cannot change
- // it after creation. When you add or modify the rules in a rule group, WAF
- // enforces this limit. You can check the capacity for a set of rules using
- // CheckCapacity.
- //
- // WAF uses WCUs to calculate and control the operating resources that are used
- // to run your rules, rule groups, and web ACLs. WAF calculates capacity differently
- // for each rule type, to reflect the relative cost of each rule. Simple rules
- // that cost little to run use fewer WCUs than more complex rules that use more
- // processing power. Rule group capacity is fixed at creation, which helps users
- // plan their web ACL WCU usage when they use a rule group. The WCU limit for
- // web ACLs is 1,500.
- //
- // Capacity is a required field
- Capacity *int64 `min:"1" type:"long" required:"true"`
- // A map of custom response keys and content bodies. When you create a rule
- // with a block action, you can send a custom response to the web request. You
- // define these for the rule group, and then use them in the rules that you
- // define in the rule group.
- //
- // For information about customizing web requests and responses, see Customizing
- // web requests and responses in WAF (https://docs.aws.amazon.com/waf/latest/developerguide/waf-custom-request-response.html)
- // in the WAF Developer Guide (https://docs.aws.amazon.com/waf/latest/developerguide/waf-chapter.html).
- //
- // For information about the limits on count and size for custom request and
- // response settings, see WAF quotas (https://docs.aws.amazon.com/waf/latest/developerguide/limits.html)
- // in the WAF Developer Guide (https://docs.aws.amazon.com/waf/latest/developerguide/waf-chapter.html).
- CustomResponseBodies map[string]*CustomResponseBody `min:"1" type:"map"`
- // A description of the rule group that helps with identification.
- Description *string `min:"1" type:"string"`
- // The name of the rule group. You cannot change the name of a rule group after
- // you create it.
- //
- // Name is a required field
- Name *string `min:"1" type:"string" required:"true"`
- // The Rule statements used to identify the web requests that you want to allow,
- // block, or count. Each rule includes one top-level statement that WAF uses
- // to identify matching web requests, and parameters that govern how WAF handles
- // them.
- Rules []*Rule `type:"list"`
- // Specifies whether this is for an Amazon CloudFront distribution or for a
- // regional application. A regional application can be an Application Load Balancer
- // (ALB), an Amazon API Gateway REST API, an AppSync GraphQL API, or an Amazon
- // Cognito user pool.
- //
- // To work with CloudFront, you must also specify the Region US East (N. Virginia)
- // as follows:
- //
- // * CLI - Specify the Region when you use the CloudFront scope: --scope=CLOUDFRONT
- // --region=us-east-1.
- //
- // * API and SDKs - For all calls, use the Region endpoint us-east-1.
- //
- // Scope is a required field
- Scope *string `type:"string" required:"true" enum:"Scope"`
- // An array of key:value pairs to associate with the resource.
- Tags []*Tag `min:"1" type:"list"`
- // Defines and enables Amazon CloudWatch metrics and web request sample collection.
- //
- // VisibilityConfig is a required field
- VisibilityConfig *VisibilityConfig `type:"structure" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s CreateRuleGroupInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s CreateRuleGroupInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CreateRuleGroupInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CreateRuleGroupInput"}
- if s.Capacity == nil {
- invalidParams.Add(request.NewErrParamRequired("Capacity"))
- }
- if s.Capacity != nil && *s.Capacity < 1 {
- invalidParams.Add(request.NewErrParamMinValue("Capacity", 1))
- }
- if s.CustomResponseBodies != nil && len(s.CustomResponseBodies) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("CustomResponseBodies", 1))
- }
- if s.Description != nil && len(*s.Description) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Description", 1))
- }
- if s.Name == nil {
- invalidParams.Add(request.NewErrParamRequired("Name"))
- }
- if s.Name != nil && len(*s.Name) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Name", 1))
- }
- if s.Scope == nil {
- invalidParams.Add(request.NewErrParamRequired("Scope"))
- }
- if s.Tags != nil && len(s.Tags) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Tags", 1))
- }
- if s.VisibilityConfig == nil {
- invalidParams.Add(request.NewErrParamRequired("VisibilityConfig"))
- }
- if s.CustomResponseBodies != nil {
- for i, v := range s.CustomResponseBodies {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "CustomResponseBodies", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if s.Rules != nil {
- for i, v := range s.Rules {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "Rules", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if s.Tags != nil {
- for i, v := range s.Tags {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "Tags", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if s.VisibilityConfig != nil {
- if err := s.VisibilityConfig.Validate(); err != nil {
- invalidParams.AddNested("VisibilityConfig", err.(request.ErrInvalidParams))
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetCapacity sets the Capacity field's value.
- func (s *CreateRuleGroupInput) SetCapacity(v int64) *CreateRuleGroupInput {
- s.Capacity = &v
- return s
- }
- // SetCustomResponseBodies sets the CustomResponseBodies field's value.
- func (s *CreateRuleGroupInput) SetCustomResponseBodies(v map[string]*CustomResponseBody) *CreateRuleGroupInput {
- s.CustomResponseBodies = v
- return s
- }
- // SetDescription sets the Description field's value.
- func (s *CreateRuleGroupInput) SetDescription(v string) *CreateRuleGroupInput {
- s.Description = &v
- return s
- }
- // SetName sets the Name field's value.
- func (s *CreateRuleGroupInput) SetName(v string) *CreateRuleGroupInput {
- s.Name = &v
- return s
- }
- // SetRules sets the Rules field's value.
- func (s *CreateRuleGroupInput) SetRules(v []*Rule) *CreateRuleGroupInput {
- s.Rules = v
- return s
- }
- // SetScope sets the Scope field's value.
- func (s *CreateRuleGroupInput) SetScope(v string) *CreateRuleGroupInput {
- s.Scope = &v
- return s
- }
- // SetTags sets the Tags field's value.
- func (s *CreateRuleGroupInput) SetTags(v []*Tag) *CreateRuleGroupInput {
- s.Tags = v
- return s
- }
- // SetVisibilityConfig sets the VisibilityConfig field's value.
- func (s *CreateRuleGroupInput) SetVisibilityConfig(v *VisibilityConfig) *CreateRuleGroupInput {
- s.VisibilityConfig = v
- return s
- }
- type CreateRuleGroupOutput struct {
- _ struct{} `type:"structure"`
- // High-level information about a RuleGroup, returned by operations like create
- // and list. This provides information like the ID, that you can use to retrieve
- // and manage a RuleGroup, and the ARN, that you provide to the RuleGroupReferenceStatement
- // to use the rule group in a Rule.
- Summary *RuleGroupSummary `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s CreateRuleGroupOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s CreateRuleGroupOutput) GoString() string {
- return s.String()
- }
- // SetSummary sets the Summary field's value.
- func (s *CreateRuleGroupOutput) SetSummary(v *RuleGroupSummary) *CreateRuleGroupOutput {
- s.Summary = v
- return s
- }
- type CreateWebACLInput struct {
- _ struct{} `type:"structure"`
- // Specifies how WAF should handle CAPTCHA evaluations for rules that don't
- // have their own CaptchaConfig settings. If you don't specify this, WAF uses
- // its default settings for CaptchaConfig.
- CaptchaConfig *CaptchaConfig `type:"structure"`
- // Specifies how WAF should handle challenge evaluations for rules that don't
- // have their own ChallengeConfig settings. If you don't specify this, WAF uses
- // its default settings for ChallengeConfig.
- ChallengeConfig *ChallengeConfig `type:"structure"`
- // A map of custom response keys and content bodies. When you create a rule
- // with a block action, you can send a custom response to the web request. You
- // define these for the web ACL, and then use them in the rules and default
- // actions that you define in the web ACL.
- //
- // For information about customizing web requests and responses, see Customizing
- // web requests and responses in WAF (https://docs.aws.amazon.com/waf/latest/developerguide/waf-custom-request-response.html)
- // in the WAF Developer Guide (https://docs.aws.amazon.com/waf/latest/developerguide/waf-chapter.html).
- //
- // For information about the limits on count and size for custom request and
- // response settings, see WAF quotas (https://docs.aws.amazon.com/waf/latest/developerguide/limits.html)
- // in the WAF Developer Guide (https://docs.aws.amazon.com/waf/latest/developerguide/waf-chapter.html).
- CustomResponseBodies map[string]*CustomResponseBody `min:"1" type:"map"`
- // The action to perform if none of the Rules contained in the WebACL match.
- //
- // DefaultAction is a required field
- DefaultAction *DefaultAction `type:"structure" required:"true"`
- // A description of the web ACL that helps with identification.
- Description *string `min:"1" type:"string"`
- // The name of the web ACL. You cannot change the name of a web ACL after you
- // create it.
- //
- // Name is a required field
- Name *string `min:"1" type:"string" required:"true"`
- // The Rule statements used to identify the web requests that you want to allow,
- // block, or count. Each rule includes one top-level statement that WAF uses
- // to identify matching web requests, and parameters that govern how WAF handles
- // them.
- Rules []*Rule `type:"list"`
- // Specifies whether this is for an Amazon CloudFront distribution or for a
- // regional application. A regional application can be an Application Load Balancer
- // (ALB), an Amazon API Gateway REST API, an AppSync GraphQL API, or an Amazon
- // Cognito user pool.
- //
- // To work with CloudFront, you must also specify the Region US East (N. Virginia)
- // as follows:
- //
- // * CLI - Specify the Region when you use the CloudFront scope: --scope=CLOUDFRONT
- // --region=us-east-1.
- //
- // * API and SDKs - For all calls, use the Region endpoint us-east-1.
- //
- // Scope is a required field
- Scope *string `type:"string" required:"true" enum:"Scope"`
- // An array of key:value pairs to associate with the resource.
- Tags []*Tag `min:"1" type:"list"`
- // Specifies the domains that WAF should accept in a web request token. This
- // enables the use of tokens across multiple protected websites. When WAF provides
- // a token, it uses the domain of the Amazon Web Services resource that the
- // web ACL is protecting. If you don't specify a list of token domains, WAF
- // accepts tokens only for the domain of the protected resource. With a token
- // domain list, WAF accepts the resource's host domain plus all domains in the
- // token domain list, including their prefixed subdomains.
- //
- // Example JSON: "TokenDomains": { "mywebsite.com", "myotherwebsite.com" }
- //
- // Public suffixes aren't allowed. For example, you can't use usa.gov or co.uk
- // as token domains.
- TokenDomains []*string `min:"1" type:"list"`
- // Defines and enables Amazon CloudWatch metrics and web request sample collection.
- //
- // VisibilityConfig is a required field
- VisibilityConfig *VisibilityConfig `type:"structure" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s CreateWebACLInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s CreateWebACLInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CreateWebACLInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CreateWebACLInput"}
- if s.CustomResponseBodies != nil && len(s.CustomResponseBodies) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("CustomResponseBodies", 1))
- }
- if s.DefaultAction == nil {
- invalidParams.Add(request.NewErrParamRequired("DefaultAction"))
- }
- if s.Description != nil && len(*s.Description) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Description", 1))
- }
- if s.Name == nil {
- invalidParams.Add(request.NewErrParamRequired("Name"))
- }
- if s.Name != nil && len(*s.Name) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Name", 1))
- }
- if s.Scope == nil {
- invalidParams.Add(request.NewErrParamRequired("Scope"))
- }
- if s.Tags != nil && len(s.Tags) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Tags", 1))
- }
- if s.TokenDomains != nil && len(s.TokenDomains) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("TokenDomains", 1))
- }
- if s.VisibilityConfig == nil {
- invalidParams.Add(request.NewErrParamRequired("VisibilityConfig"))
- }
- if s.CaptchaConfig != nil {
- if err := s.CaptchaConfig.Validate(); err != nil {
- invalidParams.AddNested("CaptchaConfig", err.(request.ErrInvalidParams))
- }
- }
- if s.ChallengeConfig != nil {
- if err := s.ChallengeConfig.Validate(); err != nil {
- invalidParams.AddNested("ChallengeConfig", err.(request.ErrInvalidParams))
- }
- }
- if s.CustomResponseBodies != nil {
- for i, v := range s.CustomResponseBodies {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "CustomResponseBodies", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if s.DefaultAction != nil {
- if err := s.DefaultAction.Validate(); err != nil {
- invalidParams.AddNested("DefaultAction", err.(request.ErrInvalidParams))
- }
- }
- if s.Rules != nil {
- for i, v := range s.Rules {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "Rules", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if s.Tags != nil {
- for i, v := range s.Tags {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "Tags", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if s.VisibilityConfig != nil {
- if err := s.VisibilityConfig.Validate(); err != nil {
- invalidParams.AddNested("VisibilityConfig", err.(request.ErrInvalidParams))
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetCaptchaConfig sets the CaptchaConfig field's value.
- func (s *CreateWebACLInput) SetCaptchaConfig(v *CaptchaConfig) *CreateWebACLInput {
- s.CaptchaConfig = v
- return s
- }
- // SetChallengeConfig sets the ChallengeConfig field's value.
- func (s *CreateWebACLInput) SetChallengeConfig(v *ChallengeConfig) *CreateWebACLInput {
- s.ChallengeConfig = v
- return s
- }
- // SetCustomResponseBodies sets the CustomResponseBodies field's value.
- func (s *CreateWebACLInput) SetCustomResponseBodies(v map[string]*CustomResponseBody) *CreateWebACLInput {
- s.CustomResponseBodies = v
- return s
- }
- // SetDefaultAction sets the DefaultAction field's value.
- func (s *CreateWebACLInput) SetDefaultAction(v *DefaultAction) *CreateWebACLInput {
- s.DefaultAction = v
- return s
- }
- // SetDescription sets the Description field's value.
- func (s *CreateWebACLInput) SetDescription(v string) *CreateWebACLInput {
- s.Description = &v
- return s
- }
- // SetName sets the Name field's value.
- func (s *CreateWebACLInput) SetName(v string) *CreateWebACLInput {
- s.Name = &v
- return s
- }
- // SetRules sets the Rules field's value.
- func (s *CreateWebACLInput) SetRules(v []*Rule) *CreateWebACLInput {
- s.Rules = v
- return s
- }
- // SetScope sets the Scope field's value.
- func (s *CreateWebACLInput) SetScope(v string) *CreateWebACLInput {
- s.Scope = &v
- return s
- }
- // SetTags sets the Tags field's value.
- func (s *CreateWebACLInput) SetTags(v []*Tag) *CreateWebACLInput {
- s.Tags = v
- return s
- }
- // SetTokenDomains sets the TokenDomains field's value.
- func (s *CreateWebACLInput) SetTokenDomains(v []*string) *CreateWebACLInput {
- s.TokenDomains = v
- return s
- }
- // SetVisibilityConfig sets the VisibilityConfig field's value.
- func (s *CreateWebACLInput) SetVisibilityConfig(v *VisibilityConfig) *CreateWebACLInput {
- s.VisibilityConfig = v
- return s
- }
- type CreateWebACLOutput struct {
- _ struct{} `type:"structure"`
- // High-level information about a WebACL, returned by operations like create
- // and list. This provides information like the ID, that you can use to retrieve
- // and manage a WebACL, and the ARN, that you provide to operations like AssociateWebACL.
- Summary *WebACLSummary `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s CreateWebACLOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s CreateWebACLOutput) GoString() string {
- return s.String()
- }
- // SetSummary sets the Summary field's value.
- func (s *CreateWebACLOutput) SetSummary(v *WebACLSummary) *CreateWebACLOutput {
- s.Summary = v
- return s
- }
- // A custom header for custom request and response handling. This is used in
- // CustomResponse and CustomRequestHandling.
- type CustomHTTPHeader struct {
- _ struct{} `type:"structure"`
- // The name of the custom header.
- //
- // For custom request header insertion, when WAF inserts the header into the
- // request, it prefixes this name x-amzn-waf-, to avoid confusion with the headers
- // that are already in the request. For example, for the header name sample,
- // WAF inserts the header x-amzn-waf-sample.
- //
- // Name is a required field
- Name *string `min:"1" type:"string" required:"true"`
- // The value of the custom header.
- //
- // Value is a required field
- Value *string `min:"1" type:"string" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s CustomHTTPHeader) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s CustomHTTPHeader) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CustomHTTPHeader) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CustomHTTPHeader"}
- if s.Name == nil {
- invalidParams.Add(request.NewErrParamRequired("Name"))
- }
- if s.Name != nil && len(*s.Name) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Name", 1))
- }
- if s.Value == nil {
- invalidParams.Add(request.NewErrParamRequired("Value"))
- }
- if s.Value != nil && len(*s.Value) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Value", 1))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetName sets the Name field's value.
- func (s *CustomHTTPHeader) SetName(v string) *CustomHTTPHeader {
- s.Name = &v
- return s
- }
- // SetValue sets the Value field's value.
- func (s *CustomHTTPHeader) SetValue(v string) *CustomHTTPHeader {
- s.Value = &v
- return s
- }
- // Custom request handling behavior that inserts custom headers into a web request.
- // You can add custom request handling for WAF to use when the rule action doesn't
- // block the request. For example, CaptchaAction for requests with valid t okens,
- // and AllowAction.
- //
- // For information about customizing web requests and responses, see Customizing
- // web requests and responses in WAF (https://docs.aws.amazon.com/waf/latest/developerguide/waf-custom-request-response.html)
- // in the WAF Developer Guide (https://docs.aws.amazon.com/waf/latest/developerguide/waf-chapter.html).
- type CustomRequestHandling struct {
- _ struct{} `type:"structure"`
- // The HTTP headers to insert into the request. Duplicate header names are not
- // allowed.
- //
- // For information about the limits on count and size for custom request and
- // response settings, see WAF quotas (https://docs.aws.amazon.com/waf/latest/developerguide/limits.html)
- // in the WAF Developer Guide (https://docs.aws.amazon.com/waf/latest/developerguide/waf-chapter.html).
- //
- // InsertHeaders is a required field
- InsertHeaders []*CustomHTTPHeader `min:"1" type:"list" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s CustomRequestHandling) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s CustomRequestHandling) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CustomRequestHandling) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CustomRequestHandling"}
- if s.InsertHeaders == nil {
- invalidParams.Add(request.NewErrParamRequired("InsertHeaders"))
- }
- if s.InsertHeaders != nil && len(s.InsertHeaders) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("InsertHeaders", 1))
- }
- if s.InsertHeaders != nil {
- for i, v := range s.InsertHeaders {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "InsertHeaders", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetInsertHeaders sets the InsertHeaders field's value.
- func (s *CustomRequestHandling) SetInsertHeaders(v []*CustomHTTPHeader) *CustomRequestHandling {
- s.InsertHeaders = v
- return s
- }
- // A custom response to send to the client. You can define a custom response
- // for rule actions and default web ACL actions that are set to BlockAction.
- //
- // For information about customizing web requests and responses, see Customizing
- // web requests and responses in WAF (https://docs.aws.amazon.com/waf/latest/developerguide/waf-custom-request-response.html)
- // in the WAF Developer Guide (https://docs.aws.amazon.com/waf/latest/developerguide/waf-chapter.html).
- type CustomResponse struct {
- _ struct{} `type:"structure"`
- // References the response body that you want WAF to return to the web request
- // client. You can define a custom response for a rule action or a default web
- // ACL action that is set to block. To do this, you first define the response
- // body key and value in the CustomResponseBodies setting for the WebACL or
- // RuleGroup where you want to use it. Then, in the rule action or web ACL default
- // action BlockAction setting, you reference the response body using this key.
- CustomResponseBodyKey *string `min:"1" type:"string"`
- // The HTTP status code to return to the client.
- //
- // For a list of status codes that you can use in your custom responses, see
- // Supported status codes for custom response (https://docs.aws.amazon.com/waf/latest/developerguide/customizing-the-response-status-codes.html)
- // in the WAF Developer Guide (https://docs.aws.amazon.com/waf/latest/developerguide/waf-chapter.html).
- //
- // ResponseCode is a required field
- ResponseCode *int64 `min:"200" type:"integer" required:"true"`
- // The HTTP headers to use in the response. Duplicate header names are not allowed.
- //
- // For information about the limits on count and size for custom request and
- // response settings, see WAF quotas (https://docs.aws.amazon.com/waf/latest/developerguide/limits.html)
- // in the WAF Developer Guide (https://docs.aws.amazon.com/waf/latest/developerguide/waf-chapter.html).
- ResponseHeaders []*CustomHTTPHeader `min:"1" type:"list"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s CustomResponse) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s CustomResponse) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CustomResponse) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CustomResponse"}
- if s.CustomResponseBodyKey != nil && len(*s.CustomResponseBodyKey) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("CustomResponseBodyKey", 1))
- }
- if s.ResponseCode == nil {
- invalidParams.Add(request.NewErrParamRequired("ResponseCode"))
- }
- if s.ResponseCode != nil && *s.ResponseCode < 200 {
- invalidParams.Add(request.NewErrParamMinValue("ResponseCode", 200))
- }
- if s.ResponseHeaders != nil && len(s.ResponseHeaders) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("ResponseHeaders", 1))
- }
- if s.ResponseHeaders != nil {
- for i, v := range s.ResponseHeaders {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "ResponseHeaders", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetCustomResponseBodyKey sets the CustomResponseBodyKey field's value.
- func (s *CustomResponse) SetCustomResponseBodyKey(v string) *CustomResponse {
- s.CustomResponseBodyKey = &v
- return s
- }
- // SetResponseCode sets the ResponseCode field's value.
- func (s *CustomResponse) SetResponseCode(v int64) *CustomResponse {
- s.ResponseCode = &v
- return s
- }
- // SetResponseHeaders sets the ResponseHeaders field's value.
- func (s *CustomResponse) SetResponseHeaders(v []*CustomHTTPHeader) *CustomResponse {
- s.ResponseHeaders = v
- return s
- }
- // The response body to use in a custom response to a web request. This is referenced
- // by key from CustomResponse CustomResponseBodyKey.
- type CustomResponseBody struct {
- _ struct{} `type:"structure"`
- // The payload of the custom response.
- //
- // You can use JSON escape strings in JSON content. To do this, you must specify
- // JSON content in the ContentType setting.
- //
- // For information about the limits on count and size for custom request and
- // response settings, see WAF quotas (https://docs.aws.amazon.com/waf/latest/developerguide/limits.html)
- // in the WAF Developer Guide (https://docs.aws.amazon.com/waf/latest/developerguide/waf-chapter.html).
- //
- // Content is a required field
- Content *string `min:"1" type:"string" required:"true"`
- // The type of content in the payload that you are defining in the Content string.
- //
- // ContentType is a required field
- ContentType *string `type:"string" required:"true" enum:"ResponseContentType"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s CustomResponseBody) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s CustomResponseBody) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *CustomResponseBody) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "CustomResponseBody"}
- if s.Content == nil {
- invalidParams.Add(request.NewErrParamRequired("Content"))
- }
- if s.Content != nil && len(*s.Content) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Content", 1))
- }
- if s.ContentType == nil {
- invalidParams.Add(request.NewErrParamRequired("ContentType"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetContent sets the Content field's value.
- func (s *CustomResponseBody) SetContent(v string) *CustomResponseBody {
- s.Content = &v
- return s
- }
- // SetContentType sets the ContentType field's value.
- func (s *CustomResponseBody) SetContentType(v string) *CustomResponseBody {
- s.ContentType = &v
- return s
- }
- // In a WebACL, this is the action that you want WAF to perform when a web request
- // doesn't match any of the rules in the WebACL. The default action must be
- // a terminating action.
- type DefaultAction struct {
- _ struct{} `type:"structure"`
- // Specifies that WAF should allow requests by default.
- Allow *AllowAction `type:"structure"`
- // Specifies that WAF should block requests by default.
- Block *BlockAction `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s DefaultAction) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s DefaultAction) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DefaultAction) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DefaultAction"}
- if s.Allow != nil {
- if err := s.Allow.Validate(); err != nil {
- invalidParams.AddNested("Allow", err.(request.ErrInvalidParams))
- }
- }
- if s.Block != nil {
- if err := s.Block.Validate(); err != nil {
- invalidParams.AddNested("Block", err.(request.ErrInvalidParams))
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetAllow sets the Allow field's value.
- func (s *DefaultAction) SetAllow(v *AllowAction) *DefaultAction {
- s.Allow = v
- return s
- }
- // SetBlock sets the Block field's value.
- func (s *DefaultAction) SetBlock(v *BlockAction) *DefaultAction {
- s.Block = v
- return s
- }
- type DeleteFirewallManagerRuleGroupsInput struct {
- _ struct{} `type:"structure"`
- // The Amazon Resource Name (ARN) of the web ACL.
- //
- // WebACLArn is a required field
- WebACLArn *string `min:"20" type:"string" required:"true"`
- // A token used for optimistic locking. WAF returns a token to your get and
- // list requests, to mark the state of the entity at the time of the request.
- // To make changes to the entity associated with the token, you provide the
- // token to operations like update and delete. WAF uses the token to ensure
- // that no changes have been made to the entity since you last retrieved it.
- // If a change has been made, the update fails with a WAFOptimisticLockException.
- // If this happens, perform another get, and use the new token returned by that
- // operation.
- //
- // WebACLLockToken is a required field
- WebACLLockToken *string `min:"1" type:"string" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s DeleteFirewallManagerRuleGroupsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s DeleteFirewallManagerRuleGroupsInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DeleteFirewallManagerRuleGroupsInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DeleteFirewallManagerRuleGroupsInput"}
- if s.WebACLArn == nil {
- invalidParams.Add(request.NewErrParamRequired("WebACLArn"))
- }
- if s.WebACLArn != nil && len(*s.WebACLArn) < 20 {
- invalidParams.Add(request.NewErrParamMinLen("WebACLArn", 20))
- }
- if s.WebACLLockToken == nil {
- invalidParams.Add(request.NewErrParamRequired("WebACLLockToken"))
- }
- if s.WebACLLockToken != nil && len(*s.WebACLLockToken) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("WebACLLockToken", 1))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetWebACLArn sets the WebACLArn field's value.
- func (s *DeleteFirewallManagerRuleGroupsInput) SetWebACLArn(v string) *DeleteFirewallManagerRuleGroupsInput {
- s.WebACLArn = &v
- return s
- }
- // SetWebACLLockToken sets the WebACLLockToken field's value.
- func (s *DeleteFirewallManagerRuleGroupsInput) SetWebACLLockToken(v string) *DeleteFirewallManagerRuleGroupsInput {
- s.WebACLLockToken = &v
- return s
- }
- type DeleteFirewallManagerRuleGroupsOutput struct {
- _ struct{} `type:"structure"`
- // A token used for optimistic locking. WAF returns a token to your get and
- // list requests, to mark the state of the entity at the time of the request.
- // To make changes to the entity associated with the token, you provide the
- // token to operations like update and delete. WAF uses the token to ensure
- // that no changes have been made to the entity since you last retrieved it.
- // If a change has been made, the update fails with a WAFOptimisticLockException.
- // If this happens, perform another get, and use the new token returned by that
- // operation.
- NextWebACLLockToken *string `min:"1" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s DeleteFirewallManagerRuleGroupsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s DeleteFirewallManagerRuleGroupsOutput) GoString() string {
- return s.String()
- }
- // SetNextWebACLLockToken sets the NextWebACLLockToken field's value.
- func (s *DeleteFirewallManagerRuleGroupsOutput) SetNextWebACLLockToken(v string) *DeleteFirewallManagerRuleGroupsOutput {
- s.NextWebACLLockToken = &v
- return s
- }
- type DeleteIPSetInput struct {
- _ struct{} `type:"structure"`
- // A unique identifier for the set. This ID is returned in the responses to
- // create and list commands. You provide it to operations like update and delete.
- //
- // Id is a required field
- Id *string `min:"1" type:"string" required:"true"`
- // A token used for optimistic locking. WAF returns a token to your get and
- // list requests, to mark the state of the entity at the time of the request.
- // To make changes to the entity associated with the token, you provide the
- // token to operations like update and delete. WAF uses the token to ensure
- // that no changes have been made to the entity since you last retrieved it.
- // If a change has been made, the update fails with a WAFOptimisticLockException.
- // If this happens, perform another get, and use the new token returned by that
- // operation.
- //
- // LockToken is a required field
- LockToken *string `min:"1" type:"string" required:"true"`
- // The name of the IP set. You cannot change the name of an IPSet after you
- // create it.
- //
- // Name is a required field
- Name *string `min:"1" type:"string" required:"true"`
- // Specifies whether this is for an Amazon CloudFront distribution or for a
- // regional application. A regional application can be an Application Load Balancer
- // (ALB), an Amazon API Gateway REST API, an AppSync GraphQL API, or an Amazon
- // Cognito user pool.
- //
- // To work with CloudFront, you must also specify the Region US East (N. Virginia)
- // as follows:
- //
- // * CLI - Specify the Region when you use the CloudFront scope: --scope=CLOUDFRONT
- // --region=us-east-1.
- //
- // * API and SDKs - For all calls, use the Region endpoint us-east-1.
- //
- // Scope is a required field
- Scope *string `type:"string" required:"true" enum:"Scope"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s DeleteIPSetInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s DeleteIPSetInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DeleteIPSetInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DeleteIPSetInput"}
- if s.Id == nil {
- invalidParams.Add(request.NewErrParamRequired("Id"))
- }
- if s.Id != nil && len(*s.Id) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Id", 1))
- }
- if s.LockToken == nil {
- invalidParams.Add(request.NewErrParamRequired("LockToken"))
- }
- if s.LockToken != nil && len(*s.LockToken) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("LockToken", 1))
- }
- if s.Name == nil {
- invalidParams.Add(request.NewErrParamRequired("Name"))
- }
- if s.Name != nil && len(*s.Name) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Name", 1))
- }
- if s.Scope == nil {
- invalidParams.Add(request.NewErrParamRequired("Scope"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetId sets the Id field's value.
- func (s *DeleteIPSetInput) SetId(v string) *DeleteIPSetInput {
- s.Id = &v
- return s
- }
- // SetLockToken sets the LockToken field's value.
- func (s *DeleteIPSetInput) SetLockToken(v string) *DeleteIPSetInput {
- s.LockToken = &v
- return s
- }
- // SetName sets the Name field's value.
- func (s *DeleteIPSetInput) SetName(v string) *DeleteIPSetInput {
- s.Name = &v
- return s
- }
- // SetScope sets the Scope field's value.
- func (s *DeleteIPSetInput) SetScope(v string) *DeleteIPSetInput {
- s.Scope = &v
- return s
- }
- type DeleteIPSetOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s DeleteIPSetOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s DeleteIPSetOutput) GoString() string {
- return s.String()
- }
- type DeleteLoggingConfigurationInput struct {
- _ struct{} `type:"structure"`
- // The Amazon Resource Name (ARN) of the web ACL from which you want to delete
- // the LoggingConfiguration.
- //
- // ResourceArn is a required field
- ResourceArn *string `min:"20" type:"string" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s DeleteLoggingConfigurationInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s DeleteLoggingConfigurationInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DeleteLoggingConfigurationInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DeleteLoggingConfigurationInput"}
- if s.ResourceArn == nil {
- invalidParams.Add(request.NewErrParamRequired("ResourceArn"))
- }
- if s.ResourceArn != nil && len(*s.ResourceArn) < 20 {
- invalidParams.Add(request.NewErrParamMinLen("ResourceArn", 20))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetResourceArn sets the ResourceArn field's value.
- func (s *DeleteLoggingConfigurationInput) SetResourceArn(v string) *DeleteLoggingConfigurationInput {
- s.ResourceArn = &v
- return s
- }
- type DeleteLoggingConfigurationOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s DeleteLoggingConfigurationOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s DeleteLoggingConfigurationOutput) GoString() string {
- return s.String()
- }
- type DeletePermissionPolicyInput struct {
- _ struct{} `type:"structure"`
- // The Amazon Resource Name (ARN) of the rule group from which you want to delete
- // the policy.
- //
- // You must be the owner of the rule group to perform this operation.
- //
- // ResourceArn is a required field
- ResourceArn *string `min:"20" type:"string" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s DeletePermissionPolicyInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s DeletePermissionPolicyInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DeletePermissionPolicyInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DeletePermissionPolicyInput"}
- if s.ResourceArn == nil {
- invalidParams.Add(request.NewErrParamRequired("ResourceArn"))
- }
- if s.ResourceArn != nil && len(*s.ResourceArn) < 20 {
- invalidParams.Add(request.NewErrParamMinLen("ResourceArn", 20))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetResourceArn sets the ResourceArn field's value.
- func (s *DeletePermissionPolicyInput) SetResourceArn(v string) *DeletePermissionPolicyInput {
- s.ResourceArn = &v
- return s
- }
- type DeletePermissionPolicyOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s DeletePermissionPolicyOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s DeletePermissionPolicyOutput) GoString() string {
- return s.String()
- }
- type DeleteRegexPatternSetInput struct {
- _ struct{} `type:"structure"`
- // A unique identifier for the set. This ID is returned in the responses to
- // create and list commands. You provide it to operations like update and delete.
- //
- // Id is a required field
- Id *string `min:"1" type:"string" required:"true"`
- // A token used for optimistic locking. WAF returns a token to your get and
- // list requests, to mark the state of the entity at the time of the request.
- // To make changes to the entity associated with the token, you provide the
- // token to operations like update and delete. WAF uses the token to ensure
- // that no changes have been made to the entity since you last retrieved it.
- // If a change has been made, the update fails with a WAFOptimisticLockException.
- // If this happens, perform another get, and use the new token returned by that
- // operation.
- //
- // LockToken is a required field
- LockToken *string `min:"1" type:"string" required:"true"`
- // The name of the set. You cannot change the name after you create the set.
- //
- // Name is a required field
- Name *string `min:"1" type:"string" required:"true"`
- // Specifies whether this is for an Amazon CloudFront distribution or for a
- // regional application. A regional application can be an Application Load Balancer
- // (ALB), an Amazon API Gateway REST API, an AppSync GraphQL API, or an Amazon
- // Cognito user pool.
- //
- // To work with CloudFront, you must also specify the Region US East (N. Virginia)
- // as follows:
- //
- // * CLI - Specify the Region when you use the CloudFront scope: --scope=CLOUDFRONT
- // --region=us-east-1.
- //
- // * API and SDKs - For all calls, use the Region endpoint us-east-1.
- //
- // Scope is a required field
- Scope *string `type:"string" required:"true" enum:"Scope"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s DeleteRegexPatternSetInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s DeleteRegexPatternSetInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DeleteRegexPatternSetInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DeleteRegexPatternSetInput"}
- if s.Id == nil {
- invalidParams.Add(request.NewErrParamRequired("Id"))
- }
- if s.Id != nil && len(*s.Id) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Id", 1))
- }
- if s.LockToken == nil {
- invalidParams.Add(request.NewErrParamRequired("LockToken"))
- }
- if s.LockToken != nil && len(*s.LockToken) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("LockToken", 1))
- }
- if s.Name == nil {
- invalidParams.Add(request.NewErrParamRequired("Name"))
- }
- if s.Name != nil && len(*s.Name) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Name", 1))
- }
- if s.Scope == nil {
- invalidParams.Add(request.NewErrParamRequired("Scope"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetId sets the Id field's value.
- func (s *DeleteRegexPatternSetInput) SetId(v string) *DeleteRegexPatternSetInput {
- s.Id = &v
- return s
- }
- // SetLockToken sets the LockToken field's value.
- func (s *DeleteRegexPatternSetInput) SetLockToken(v string) *DeleteRegexPatternSetInput {
- s.LockToken = &v
- return s
- }
- // SetName sets the Name field's value.
- func (s *DeleteRegexPatternSetInput) SetName(v string) *DeleteRegexPatternSetInput {
- s.Name = &v
- return s
- }
- // SetScope sets the Scope field's value.
- func (s *DeleteRegexPatternSetInput) SetScope(v string) *DeleteRegexPatternSetInput {
- s.Scope = &v
- return s
- }
- type DeleteRegexPatternSetOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s DeleteRegexPatternSetOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s DeleteRegexPatternSetOutput) GoString() string {
- return s.String()
- }
- type DeleteRuleGroupInput struct {
- _ struct{} `type:"structure"`
- // A unique identifier for the rule group. This ID is returned in the responses
- // to create and list commands. You provide it to operations like update and
- // delete.
- //
- // Id is a required field
- Id *string `min:"1" type:"string" required:"true"`
- // A token used for optimistic locking. WAF returns a token to your get and
- // list requests, to mark the state of the entity at the time of the request.
- // To make changes to the entity associated with the token, you provide the
- // token to operations like update and delete. WAF uses the token to ensure
- // that no changes have been made to the entity since you last retrieved it.
- // If a change has been made, the update fails with a WAFOptimisticLockException.
- // If this happens, perform another get, and use the new token returned by that
- // operation.
- //
- // LockToken is a required field
- LockToken *string `min:"1" type:"string" required:"true"`
- // The name of the rule group. You cannot change the name of a rule group after
- // you create it.
- //
- // Name is a required field
- Name *string `min:"1" type:"string" required:"true"`
- // Specifies whether this is for an Amazon CloudFront distribution or for a
- // regional application. A regional application can be an Application Load Balancer
- // (ALB), an Amazon API Gateway REST API, an AppSync GraphQL API, or an Amazon
- // Cognito user pool.
- //
- // To work with CloudFront, you must also specify the Region US East (N. Virginia)
- // as follows:
- //
- // * CLI - Specify the Region when you use the CloudFront scope: --scope=CLOUDFRONT
- // --region=us-east-1.
- //
- // * API and SDKs - For all calls, use the Region endpoint us-east-1.
- //
- // Scope is a required field
- Scope *string `type:"string" required:"true" enum:"Scope"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s DeleteRuleGroupInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s DeleteRuleGroupInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DeleteRuleGroupInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DeleteRuleGroupInput"}
- if s.Id == nil {
- invalidParams.Add(request.NewErrParamRequired("Id"))
- }
- if s.Id != nil && len(*s.Id) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Id", 1))
- }
- if s.LockToken == nil {
- invalidParams.Add(request.NewErrParamRequired("LockToken"))
- }
- if s.LockToken != nil && len(*s.LockToken) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("LockToken", 1))
- }
- if s.Name == nil {
- invalidParams.Add(request.NewErrParamRequired("Name"))
- }
- if s.Name != nil && len(*s.Name) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Name", 1))
- }
- if s.Scope == nil {
- invalidParams.Add(request.NewErrParamRequired("Scope"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetId sets the Id field's value.
- func (s *DeleteRuleGroupInput) SetId(v string) *DeleteRuleGroupInput {
- s.Id = &v
- return s
- }
- // SetLockToken sets the LockToken field's value.
- func (s *DeleteRuleGroupInput) SetLockToken(v string) *DeleteRuleGroupInput {
- s.LockToken = &v
- return s
- }
- // SetName sets the Name field's value.
- func (s *DeleteRuleGroupInput) SetName(v string) *DeleteRuleGroupInput {
- s.Name = &v
- return s
- }
- // SetScope sets the Scope field's value.
- func (s *DeleteRuleGroupInput) SetScope(v string) *DeleteRuleGroupInput {
- s.Scope = &v
- return s
- }
- type DeleteRuleGroupOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s DeleteRuleGroupOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s DeleteRuleGroupOutput) GoString() string {
- return s.String()
- }
- type DeleteWebACLInput struct {
- _ struct{} `type:"structure"`
- // The unique identifier for the web ACL. This ID is returned in the responses
- // to create and list commands. You provide it to operations like update and
- // delete.
- //
- // Id is a required field
- Id *string `min:"1" type:"string" required:"true"`
- // A token used for optimistic locking. WAF returns a token to your get and
- // list requests, to mark the state of the entity at the time of the request.
- // To make changes to the entity associated with the token, you provide the
- // token to operations like update and delete. WAF uses the token to ensure
- // that no changes have been made to the entity since you last retrieved it.
- // If a change has been made, the update fails with a WAFOptimisticLockException.
- // If this happens, perform another get, and use the new token returned by that
- // operation.
- //
- // LockToken is a required field
- LockToken *string `min:"1" type:"string" required:"true"`
- // The name of the web ACL. You cannot change the name of a web ACL after you
- // create it.
- //
- // Name is a required field
- Name *string `min:"1" type:"string" required:"true"`
- // Specifies whether this is for an Amazon CloudFront distribution or for a
- // regional application. A regional application can be an Application Load Balancer
- // (ALB), an Amazon API Gateway REST API, an AppSync GraphQL API, or an Amazon
- // Cognito user pool.
- //
- // To work with CloudFront, you must also specify the Region US East (N. Virginia)
- // as follows:
- //
- // * CLI - Specify the Region when you use the CloudFront scope: --scope=CLOUDFRONT
- // --region=us-east-1.
- //
- // * API and SDKs - For all calls, use the Region endpoint us-east-1.
- //
- // Scope is a required field
- Scope *string `type:"string" required:"true" enum:"Scope"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s DeleteWebACLInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s DeleteWebACLInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DeleteWebACLInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DeleteWebACLInput"}
- if s.Id == nil {
- invalidParams.Add(request.NewErrParamRequired("Id"))
- }
- if s.Id != nil && len(*s.Id) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Id", 1))
- }
- if s.LockToken == nil {
- invalidParams.Add(request.NewErrParamRequired("LockToken"))
- }
- if s.LockToken != nil && len(*s.LockToken) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("LockToken", 1))
- }
- if s.Name == nil {
- invalidParams.Add(request.NewErrParamRequired("Name"))
- }
- if s.Name != nil && len(*s.Name) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Name", 1))
- }
- if s.Scope == nil {
- invalidParams.Add(request.NewErrParamRequired("Scope"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetId sets the Id field's value.
- func (s *DeleteWebACLInput) SetId(v string) *DeleteWebACLInput {
- s.Id = &v
- return s
- }
- // SetLockToken sets the LockToken field's value.
- func (s *DeleteWebACLInput) SetLockToken(v string) *DeleteWebACLInput {
- s.LockToken = &v
- return s
- }
- // SetName sets the Name field's value.
- func (s *DeleteWebACLInput) SetName(v string) *DeleteWebACLInput {
- s.Name = &v
- return s
- }
- // SetScope sets the Scope field's value.
- func (s *DeleteWebACLInput) SetScope(v string) *DeleteWebACLInput {
- s.Scope = &v
- return s
- }
- type DeleteWebACLOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s DeleteWebACLOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s DeleteWebACLOutput) GoString() string {
- return s.String()
- }
- type DescribeManagedRuleGroupInput struct {
- _ struct{} `type:"structure"`
- // The name of the managed rule group. You use this, along with the vendor name,
- // to identify the rule group.
- //
- // Name is a required field
- Name *string `min:"1" type:"string" required:"true"`
- // Specifies whether this is for an Amazon CloudFront distribution or for a
- // regional application. A regional application can be an Application Load Balancer
- // (ALB), an Amazon API Gateway REST API, an AppSync GraphQL API, or an Amazon
- // Cognito user pool.
- //
- // To work with CloudFront, you must also specify the Region US East (N. Virginia)
- // as follows:
- //
- // * CLI - Specify the Region when you use the CloudFront scope: --scope=CLOUDFRONT
- // --region=us-east-1.
- //
- // * API and SDKs - For all calls, use the Region endpoint us-east-1.
- //
- // Scope is a required field
- Scope *string `type:"string" required:"true" enum:"Scope"`
- // The name of the managed rule group vendor. You use this, along with the rule
- // group name, to identify the rule group.
- //
- // VendorName is a required field
- VendorName *string `min:"1" type:"string" required:"true"`
- // The version of the rule group. You can only use a version that is not scheduled
- // for expiration. If you don't provide this, WAF uses the vendor's default
- // version.
- VersionName *string `min:"1" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s DescribeManagedRuleGroupInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s DescribeManagedRuleGroupInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DescribeManagedRuleGroupInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DescribeManagedRuleGroupInput"}
- if s.Name == nil {
- invalidParams.Add(request.NewErrParamRequired("Name"))
- }
- if s.Name != nil && len(*s.Name) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Name", 1))
- }
- if s.Scope == nil {
- invalidParams.Add(request.NewErrParamRequired("Scope"))
- }
- if s.VendorName == nil {
- invalidParams.Add(request.NewErrParamRequired("VendorName"))
- }
- if s.VendorName != nil && len(*s.VendorName) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("VendorName", 1))
- }
- if s.VersionName != nil && len(*s.VersionName) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("VersionName", 1))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetName sets the Name field's value.
- func (s *DescribeManagedRuleGroupInput) SetName(v string) *DescribeManagedRuleGroupInput {
- s.Name = &v
- return s
- }
- // SetScope sets the Scope field's value.
- func (s *DescribeManagedRuleGroupInput) SetScope(v string) *DescribeManagedRuleGroupInput {
- s.Scope = &v
- return s
- }
- // SetVendorName sets the VendorName field's value.
- func (s *DescribeManagedRuleGroupInput) SetVendorName(v string) *DescribeManagedRuleGroupInput {
- s.VendorName = &v
- return s
- }
- // SetVersionName sets the VersionName field's value.
- func (s *DescribeManagedRuleGroupInput) SetVersionName(v string) *DescribeManagedRuleGroupInput {
- s.VersionName = &v
- return s
- }
- type DescribeManagedRuleGroupOutput struct {
- _ struct{} `type:"structure"`
- // The labels that one or more rules in this rule group add to matching web
- // requests. These labels are defined in the RuleLabels for a Rule.
- AvailableLabels []*LabelSummary `type:"list"`
- // The web ACL capacity units (WCUs) required for this rule group. WAF uses
- // web ACL capacity units (WCU) to calculate and control the operating resources
- // that are used to run your rules, rule groups, and web ACLs. WAF calculates
- // capacity differently for each rule type, to reflect each rule's relative
- // cost. Rule group capacity is fixed at creation, so users can plan their web
- // ACL WCU usage when they use a rule group. The WCU limit for web ACLs is 1,500.
- Capacity *int64 `min:"1" type:"long"`
- // The labels that one or more rules in this rule group match against in label
- // match statements. These labels are defined in a LabelMatchStatement specification,
- // in the Statement definition of a rule.
- ConsumedLabels []*LabelSummary `type:"list"`
- // The label namespace prefix for this rule group. All labels added by rules
- // in this rule group have this prefix.
- //
- // * The syntax for the label namespace prefix for a managed rule group is
- // the following: awswaf:managed:<vendor>:<rule group name>:
- //
- // * When a rule with a label matches a web request, WAF adds the fully qualified
- // label to the request. A fully qualified label is made up of the label
- // namespace from the rule group or web ACL where the rule is defined and
- // the label from the rule, separated by a colon: <label namespace>:<label
- // from rule>
- LabelNamespace *string `min:"1" type:"string"`
- Rules []*RuleSummary `type:"list"`
- // The Amazon resource name (ARN) of the Amazon Simple Notification Service
- // SNS topic that's used to record changes to the managed rule group. You can
- // subscribe to the SNS topic to receive notifications when the managed rule
- // group is modified, such as for new versions and for version expiration. For
- // more information, see the Amazon Simple Notification Service Developer Guide
- // (https://docs.aws.amazon.com/sns/latest/dg/welcome.html).
- SnsTopicArn *string `min:"20" type:"string"`
- // The managed rule group's version.
- VersionName *string `min:"1" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s DescribeManagedRuleGroupOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s DescribeManagedRuleGroupOutput) GoString() string {
- return s.String()
- }
- // SetAvailableLabels sets the AvailableLabels field's value.
- func (s *DescribeManagedRuleGroupOutput) SetAvailableLabels(v []*LabelSummary) *DescribeManagedRuleGroupOutput {
- s.AvailableLabels = v
- return s
- }
- // SetCapacity sets the Capacity field's value.
- func (s *DescribeManagedRuleGroupOutput) SetCapacity(v int64) *DescribeManagedRuleGroupOutput {
- s.Capacity = &v
- return s
- }
- // SetConsumedLabels sets the ConsumedLabels field's value.
- func (s *DescribeManagedRuleGroupOutput) SetConsumedLabels(v []*LabelSummary) *DescribeManagedRuleGroupOutput {
- s.ConsumedLabels = v
- return s
- }
- // SetLabelNamespace sets the LabelNamespace field's value.
- func (s *DescribeManagedRuleGroupOutput) SetLabelNamespace(v string) *DescribeManagedRuleGroupOutput {
- s.LabelNamespace = &v
- return s
- }
- // SetRules sets the Rules field's value.
- func (s *DescribeManagedRuleGroupOutput) SetRules(v []*RuleSummary) *DescribeManagedRuleGroupOutput {
- s.Rules = v
- return s
- }
- // SetSnsTopicArn sets the SnsTopicArn field's value.
- func (s *DescribeManagedRuleGroupOutput) SetSnsTopicArn(v string) *DescribeManagedRuleGroupOutput {
- s.SnsTopicArn = &v
- return s
- }
- // SetVersionName sets the VersionName field's value.
- func (s *DescribeManagedRuleGroupOutput) SetVersionName(v string) *DescribeManagedRuleGroupOutput {
- s.VersionName = &v
- return s
- }
- type DisassociateWebACLInput struct {
- _ struct{} `type:"structure"`
- // The Amazon Resource Name (ARN) of the resource to disassociate from the web
- // ACL.
- //
- // The ARN must be in one of the following formats:
- //
- // * For an Application Load Balancer: arn:aws:elasticloadbalancing:region:account-id:loadbalancer/app/load-balancer-name/load-balancer-id
- //
- // * For an Amazon API Gateway REST API: arn:aws:apigateway:region::/restapis/api-id/stages/stage-name
- //
- // * For an AppSync GraphQL API: arn:aws:appsync:region:account-id:apis/GraphQLApiId
- //
- // * For an Amazon Cognito user pool: arn:aws:cognito-idp:region:account-id:userpool/user-pool-id
- //
- // ResourceArn is a required field
- ResourceArn *string `min:"20" type:"string" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s DisassociateWebACLInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s DisassociateWebACLInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *DisassociateWebACLInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "DisassociateWebACLInput"}
- if s.ResourceArn == nil {
- invalidParams.Add(request.NewErrParamRequired("ResourceArn"))
- }
- if s.ResourceArn != nil && len(*s.ResourceArn) < 20 {
- invalidParams.Add(request.NewErrParamMinLen("ResourceArn", 20))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetResourceArn sets the ResourceArn field's value.
- func (s *DisassociateWebACLInput) SetResourceArn(v string) *DisassociateWebACLInput {
- s.ResourceArn = &v
- return s
- }
- type DisassociateWebACLOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s DisassociateWebACLOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s DisassociateWebACLOutput) GoString() string {
- return s.String()
- }
- // Specifies a single rule in a rule group whose action you want to override
- // to Count.
- //
- // Instead of this option, use RuleActionOverrides. It accepts any valid action
- // setting, including Count.
- type ExcludedRule struct {
- _ struct{} `type:"structure"`
- // The name of the rule whose action you want to override to Count.
- //
- // Name is a required field
- Name *string `min:"1" type:"string" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ExcludedRule) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ExcludedRule) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ExcludedRule) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ExcludedRule"}
- if s.Name == nil {
- invalidParams.Add(request.NewErrParamRequired("Name"))
- }
- if s.Name != nil && len(*s.Name) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Name", 1))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetName sets the Name field's value.
- func (s *ExcludedRule) SetName(v string) *ExcludedRule {
- s.Name = &v
- return s
- }
- // The part of the web request that you want WAF to inspect. Include the single
- // FieldToMatch type that you want to inspect, with additional specifications
- // as needed, according to the type. You specify a single request component
- // in FieldToMatch for each rule statement that requires it. To inspect more
- // than one component of the web request, create a separate rule statement for
- // each component.
- //
- // Example JSON for a QueryString field to match:
- //
- // "FieldToMatch": { "QueryString": {} }
- //
- // Example JSON for a Method field to match specification:
- //
- // "FieldToMatch": { "Method": { "Name": "DELETE" } }
- type FieldToMatch struct {
- _ struct{} `type:"structure"`
- // Inspect all query arguments.
- AllQueryArguments *AllQueryArguments `type:"structure"`
- // Inspect the request body as plain text. The request body immediately follows
- // the request headers. This is the part of a request that contains any additional
- // data that you want to send to your web server as the HTTP request body, such
- // as data from a form.
- //
- // Only the first 8 KB (8192 bytes) of the request body are forwarded to WAF
- // for inspection by the underlying host service. For information about how
- // to handle oversized request bodies, see the Body object configuration.
- Body *Body `type:"structure"`
- // Inspect the request cookies. You must configure scope and pattern matching
- // filters in the Cookies object, to define the set of cookies and the parts
- // of the cookies that WAF inspects.
- //
- // Only the first 8 KB (8192 bytes) of a request's cookies and only the first
- // 200 cookies are forwarded to WAF for inspection by the underlying host service.
- // You must configure how to handle any oversize cookie content in the Cookies
- // object. WAF applies the pattern matching filters to the cookies that it receives
- // from the underlying host service.
- Cookies *Cookies `type:"structure"`
- // Inspect the request headers. You must configure scope and pattern matching
- // filters in the Headers object, to define the set of headers to and the parts
- // of the headers that WAF inspects.
- //
- // Only the first 8 KB (8192 bytes) of a request's headers and only the first
- // 200 headers are forwarded to WAF for inspection by the underlying host service.
- // You must configure how to handle any oversize header content in the Headers
- // object. WAF applies the pattern matching filters to the headers that it receives
- // from the underlying host service.
- Headers *Headers `type:"structure"`
- // Inspect the request body as JSON. The request body immediately follows the
- // request headers. This is the part of a request that contains any additional
- // data that you want to send to your web server as the HTTP request body, such
- // as data from a form.
- //
- // Only the first 8 KB (8192 bytes) of the request body are forwarded to WAF
- // for inspection by the underlying host service. For information about how
- // to handle oversized request bodies, see the JsonBody object configuration.
- JsonBody *JsonBody `type:"structure"`
- // Inspect the HTTP method. The method indicates the type of operation that
- // the request is asking the origin to perform.
- Method *Method `type:"structure"`
- // Inspect the query string. This is the part of a URL that appears after a
- // ? character, if any.
- QueryString *QueryString `type:"structure"`
- // Inspect a single header. Provide the name of the header to inspect, for example,
- // User-Agent or Referer. This setting isn't case sensitive.
- //
- // Example JSON: "SingleHeader": { "Name": "haystack" }
- //
- // Alternately, you can filter and inspect all headers with the Headers FieldToMatch
- // setting.
- SingleHeader *SingleHeader `type:"structure"`
- // Inspect a single query argument. Provide the name of the query argument to
- // inspect, such as UserName or SalesRegion. The name can be up to 30 characters
- // long and isn't case sensitive.
- //
- // Example JSON: "SingleQueryArgument": { "Name": "myArgument" }
- SingleQueryArgument *SingleQueryArgument `type:"structure"`
- // Inspect the request URI path. This is the part of the web request that identifies
- // a resource, for example, /images/daily-ad.jpg.
- UriPath *UriPath `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s FieldToMatch) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s FieldToMatch) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *FieldToMatch) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "FieldToMatch"}
- if s.Cookies != nil {
- if err := s.Cookies.Validate(); err != nil {
- invalidParams.AddNested("Cookies", err.(request.ErrInvalidParams))
- }
- }
- if s.Headers != nil {
- if err := s.Headers.Validate(); err != nil {
- invalidParams.AddNested("Headers", err.(request.ErrInvalidParams))
- }
- }
- if s.JsonBody != nil {
- if err := s.JsonBody.Validate(); err != nil {
- invalidParams.AddNested("JsonBody", err.(request.ErrInvalidParams))
- }
- }
- if s.SingleHeader != nil {
- if err := s.SingleHeader.Validate(); err != nil {
- invalidParams.AddNested("SingleHeader", err.(request.ErrInvalidParams))
- }
- }
- if s.SingleQueryArgument != nil {
- if err := s.SingleQueryArgument.Validate(); err != nil {
- invalidParams.AddNested("SingleQueryArgument", err.(request.ErrInvalidParams))
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetAllQueryArguments sets the AllQueryArguments field's value.
- func (s *FieldToMatch) SetAllQueryArguments(v *AllQueryArguments) *FieldToMatch {
- s.AllQueryArguments = v
- return s
- }
- // SetBody sets the Body field's value.
- func (s *FieldToMatch) SetBody(v *Body) *FieldToMatch {
- s.Body = v
- return s
- }
- // SetCookies sets the Cookies field's value.
- func (s *FieldToMatch) SetCookies(v *Cookies) *FieldToMatch {
- s.Cookies = v
- return s
- }
- // SetHeaders sets the Headers field's value.
- func (s *FieldToMatch) SetHeaders(v *Headers) *FieldToMatch {
- s.Headers = v
- return s
- }
- // SetJsonBody sets the JsonBody field's value.
- func (s *FieldToMatch) SetJsonBody(v *JsonBody) *FieldToMatch {
- s.JsonBody = v
- return s
- }
- // SetMethod sets the Method field's value.
- func (s *FieldToMatch) SetMethod(v *Method) *FieldToMatch {
- s.Method = v
- return s
- }
- // SetQueryString sets the QueryString field's value.
- func (s *FieldToMatch) SetQueryString(v *QueryString) *FieldToMatch {
- s.QueryString = v
- return s
- }
- // SetSingleHeader sets the SingleHeader field's value.
- func (s *FieldToMatch) SetSingleHeader(v *SingleHeader) *FieldToMatch {
- s.SingleHeader = v
- return s
- }
- // SetSingleQueryArgument sets the SingleQueryArgument field's value.
- func (s *FieldToMatch) SetSingleQueryArgument(v *SingleQueryArgument) *FieldToMatch {
- s.SingleQueryArgument = v
- return s
- }
- // SetUriPath sets the UriPath field's value.
- func (s *FieldToMatch) SetUriPath(v *UriPath) *FieldToMatch {
- s.UriPath = v
- return s
- }
- // A single logging filter, used in LoggingFilter.
- type Filter struct {
- _ struct{} `type:"structure"`
- // How to handle logs that satisfy the filter's conditions and requirement.
- //
- // Behavior is a required field
- Behavior *string `type:"string" required:"true" enum:"FilterBehavior"`
- // Match conditions for the filter.
- //
- // Conditions is a required field
- Conditions []*Condition `min:"1" type:"list" required:"true"`
- // Logic to apply to the filtering conditions. You can specify that, in order
- // to satisfy the filter, a log must match all conditions or must match at least
- // one condition.
- //
- // Requirement is a required field
- Requirement *string `type:"string" required:"true" enum:"FilterRequirement"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s Filter) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s Filter) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *Filter) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "Filter"}
- if s.Behavior == nil {
- invalidParams.Add(request.NewErrParamRequired("Behavior"))
- }
- if s.Conditions == nil {
- invalidParams.Add(request.NewErrParamRequired("Conditions"))
- }
- if s.Conditions != nil && len(s.Conditions) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Conditions", 1))
- }
- if s.Requirement == nil {
- invalidParams.Add(request.NewErrParamRequired("Requirement"))
- }
- if s.Conditions != nil {
- for i, v := range s.Conditions {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "Conditions", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetBehavior sets the Behavior field's value.
- func (s *Filter) SetBehavior(v string) *Filter {
- s.Behavior = &v
- return s
- }
- // SetConditions sets the Conditions field's value.
- func (s *Filter) SetConditions(v []*Condition) *Filter {
- s.Conditions = v
- return s
- }
- // SetRequirement sets the Requirement field's value.
- func (s *Filter) SetRequirement(v string) *Filter {
- s.Requirement = &v
- return s
- }
- // A rule group that's defined for an Firewall Manager WAF policy.
- type FirewallManagerRuleGroup struct {
- _ struct{} `type:"structure"`
- // The processing guidance for an Firewall Manager rule. This is like a regular
- // rule Statement, but it can only contain a rule group reference.
- //
- // FirewallManagerStatement is a required field
- FirewallManagerStatement *FirewallManagerStatement `type:"structure" required:"true"`
- // The name of the rule group. You cannot change the name of a rule group after
- // you create it.
- //
- // Name is a required field
- Name *string `min:"1" type:"string" required:"true"`
- // The action to use in the place of the action that results from the rule group
- // evaluation. Set the override action to none to leave the result of the rule
- // group alone. Set it to count to override the result to count only.
- //
- // You can only use this for rule statements that reference a rule group, like
- // RuleGroupReferenceStatement and ManagedRuleGroupStatement.
- //
- // This option is usually set to none. It does not affect how the rules in the
- // rule group are evaluated. If you want the rules in the rule group to only
- // count matches, do not use this and instead use the rule action override option,
- // with Count action, in your rule group reference statement settings.
- //
- // OverrideAction is a required field
- OverrideAction *OverrideAction `type:"structure" required:"true"`
- // If you define more than one rule group in the first or last Firewall Manager
- // rule groups, WAF evaluates each request against the rule groups in order,
- // starting from the lowest priority setting. The priorities don't need to be
- // consecutive, but they must all be different.
- //
- // Priority is a required field
- Priority *int64 `type:"integer" required:"true"`
- // Defines and enables Amazon CloudWatch metrics and web request sample collection.
- //
- // VisibilityConfig is a required field
- VisibilityConfig *VisibilityConfig `type:"structure" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s FirewallManagerRuleGroup) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s FirewallManagerRuleGroup) GoString() string {
- return s.String()
- }
- // SetFirewallManagerStatement sets the FirewallManagerStatement field's value.
- func (s *FirewallManagerRuleGroup) SetFirewallManagerStatement(v *FirewallManagerStatement) *FirewallManagerRuleGroup {
- s.FirewallManagerStatement = v
- return s
- }
- // SetName sets the Name field's value.
- func (s *FirewallManagerRuleGroup) SetName(v string) *FirewallManagerRuleGroup {
- s.Name = &v
- return s
- }
- // SetOverrideAction sets the OverrideAction field's value.
- func (s *FirewallManagerRuleGroup) SetOverrideAction(v *OverrideAction) *FirewallManagerRuleGroup {
- s.OverrideAction = v
- return s
- }
- // SetPriority sets the Priority field's value.
- func (s *FirewallManagerRuleGroup) SetPriority(v int64) *FirewallManagerRuleGroup {
- s.Priority = &v
- return s
- }
- // SetVisibilityConfig sets the VisibilityConfig field's value.
- func (s *FirewallManagerRuleGroup) SetVisibilityConfig(v *VisibilityConfig) *FirewallManagerRuleGroup {
- s.VisibilityConfig = v
- return s
- }
- // The processing guidance for an Firewall Manager rule. This is like a regular
- // rule Statement, but it can only contain a rule group reference.
- type FirewallManagerStatement struct {
- _ struct{} `type:"structure"`
- // A rule statement used to run the rules that are defined in a managed rule
- // group. To use this, provide the vendor name and the name of the rule group
- // in this statement. You can retrieve the required names by calling ListAvailableManagedRuleGroups.
- //
- // You cannot nest a ManagedRuleGroupStatement, for example for use inside a
- // NotStatement or OrStatement. It can only be referenced as a top-level statement
- // within a rule.
- //
- // You are charged additional fees when you use the WAF Bot Control managed
- // rule group AWSManagedRulesBotControlRuleSet or the WAF Fraud Control account
- // takeover prevention (ATP) managed rule group AWSManagedRulesATPRuleSet. For
- // more information, see WAF Pricing (http://aws.amazon.com/waf/pricing/).
- ManagedRuleGroupStatement *ManagedRuleGroupStatement `type:"structure"`
- // A rule statement used to run the rules that are defined in a RuleGroup. To
- // use this, create a rule group with your rules, then provide the ARN of the
- // rule group in this statement.
- //
- // You cannot nest a RuleGroupReferenceStatement, for example for use inside
- // a NotStatement or OrStatement. You can only use a rule group reference statement
- // at the top level inside a web ACL.
- RuleGroupReferenceStatement *RuleGroupReferenceStatement `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s FirewallManagerStatement) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s FirewallManagerStatement) GoString() string {
- return s.String()
- }
- // SetManagedRuleGroupStatement sets the ManagedRuleGroupStatement field's value.
- func (s *FirewallManagerStatement) SetManagedRuleGroupStatement(v *ManagedRuleGroupStatement) *FirewallManagerStatement {
- s.ManagedRuleGroupStatement = v
- return s
- }
- // SetRuleGroupReferenceStatement sets the RuleGroupReferenceStatement field's value.
- func (s *FirewallManagerStatement) SetRuleGroupReferenceStatement(v *RuleGroupReferenceStatement) *FirewallManagerStatement {
- s.RuleGroupReferenceStatement = v
- return s
- }
- // The configuration for inspecting IP addresses in an HTTP header that you
- // specify, instead of using the IP address that's reported by the web request
- // origin. Commonly, this is the X-Forwarded-For (XFF) header, but you can specify
- // any header name.
- //
- // If the specified header isn't present in the request, WAF doesn't apply the
- // rule to the web request at all.
- //
- // This configuration is used for GeoMatchStatement and RateBasedStatement.
- // For IPSetReferenceStatement, use IPSetForwardedIPConfig instead.
- //
- // WAF only evaluates the first IP address found in the specified HTTP header.
- type ForwardedIPConfig struct {
- _ struct{} `type:"structure"`
- // The match status to assign to the web request if the request doesn't have
- // a valid IP address in the specified position.
- //
- // If the specified header isn't present in the request, WAF doesn't apply the
- // rule to the web request at all.
- //
- // You can specify the following fallback behaviors:
- //
- // * MATCH - Treat the web request as matching the rule statement. WAF applies
- // the rule action to the request.
- //
- // * NO_MATCH - Treat the web request as not matching the rule statement.
- //
- // FallbackBehavior is a required field
- FallbackBehavior *string `type:"string" required:"true" enum:"FallbackBehavior"`
- // The name of the HTTP header to use for the IP address. For example, to use
- // the X-Forwarded-For (XFF) header, set this to X-Forwarded-For.
- //
- // If the specified header isn't present in the request, WAF doesn't apply the
- // rule to the web request at all.
- //
- // HeaderName is a required field
- HeaderName *string `min:"1" type:"string" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ForwardedIPConfig) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ForwardedIPConfig) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ForwardedIPConfig) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ForwardedIPConfig"}
- if s.FallbackBehavior == nil {
- invalidParams.Add(request.NewErrParamRequired("FallbackBehavior"))
- }
- if s.HeaderName == nil {
- invalidParams.Add(request.NewErrParamRequired("HeaderName"))
- }
- if s.HeaderName != nil && len(*s.HeaderName) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("HeaderName", 1))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetFallbackBehavior sets the FallbackBehavior field's value.
- func (s *ForwardedIPConfig) SetFallbackBehavior(v string) *ForwardedIPConfig {
- s.FallbackBehavior = &v
- return s
- }
- // SetHeaderName sets the HeaderName field's value.
- func (s *ForwardedIPConfig) SetHeaderName(v string) *ForwardedIPConfig {
- s.HeaderName = &v
- return s
- }
- type GenerateMobileSdkReleaseUrlInput struct {
- _ struct{} `type:"structure"`
- // The device platform.
- //
- // Platform is a required field
- Platform *string `type:"string" required:"true" enum:"Platform"`
- // The release version. For the latest available version, specify LATEST.
- //
- // ReleaseVersion is a required field
- ReleaseVersion *string `min:"1" type:"string" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GenerateMobileSdkReleaseUrlInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GenerateMobileSdkReleaseUrlInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *GenerateMobileSdkReleaseUrlInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "GenerateMobileSdkReleaseUrlInput"}
- if s.Platform == nil {
- invalidParams.Add(request.NewErrParamRequired("Platform"))
- }
- if s.ReleaseVersion == nil {
- invalidParams.Add(request.NewErrParamRequired("ReleaseVersion"))
- }
- if s.ReleaseVersion != nil && len(*s.ReleaseVersion) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("ReleaseVersion", 1))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetPlatform sets the Platform field's value.
- func (s *GenerateMobileSdkReleaseUrlInput) SetPlatform(v string) *GenerateMobileSdkReleaseUrlInput {
- s.Platform = &v
- return s
- }
- // SetReleaseVersion sets the ReleaseVersion field's value.
- func (s *GenerateMobileSdkReleaseUrlInput) SetReleaseVersion(v string) *GenerateMobileSdkReleaseUrlInput {
- s.ReleaseVersion = &v
- return s
- }
- type GenerateMobileSdkReleaseUrlOutput struct {
- _ struct{} `type:"structure"`
- // The presigned download URL for the specified SDK release.
- Url *string `type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GenerateMobileSdkReleaseUrlOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GenerateMobileSdkReleaseUrlOutput) GoString() string {
- return s.String()
- }
- // SetUrl sets the Url field's value.
- func (s *GenerateMobileSdkReleaseUrlOutput) SetUrl(v string) *GenerateMobileSdkReleaseUrlOutput {
- s.Url = &v
- return s
- }
- // A rule statement that labels web requests by country and region and that
- // matches against web requests based on country code. A geo match rule labels
- // every request that it inspects regardless of whether it finds a match.
- //
- // - To manage requests only by country, you can use this statement by itself
- // and specify the countries that you want to match against in the CountryCodes
- // array.
- //
- // - Otherwise, configure your geo match rule with Count action so that it
- // only labels requests. Then, add one or more label match rules to run after
- // the geo match rule and configure them to match against the geographic
- // labels and handle the requests as needed.
- //
- // WAF labels requests using the alpha-2 country and region codes from the International
- // Organization for Standardization (ISO) 3166 standard. WAF determines the
- // codes using either the IP address in the web request origin or, if you specify
- // it, the address in the geo match ForwardedIPConfig.
- //
- // If you use the web request origin, the label formats are awswaf:clientip:geo:region:<ISO
- // country code>-<ISO region code> and awswaf:clientip:geo:country:<ISO country
- // code>.
- //
- // If you use a forwarded IP address, the label formats are awswaf:forwardedip:geo:region:<ISO
- // country code>-<ISO region code> and awswaf:forwardedip:geo:country:<ISO country
- // code>.
- //
- // For additional details, see Geographic match rule statement (https://docs.aws.amazon.com/waf/latest/developerguide/waf-rule-statement-type-geo-match.html)
- // in the WAF Developer Guide (https://docs.aws.amazon.com/waf/latest/developerguide/waf-chapter.html).
- type GeoMatchStatement struct {
- _ struct{} `type:"structure"`
- // An array of two-character country codes that you want to match against, for
- // example, [ "US", "CN" ], from the alpha-2 country ISO codes of the ISO 3166
- // international standard.
- //
- // When you use a geo match statement just for the region and country labels
- // that it adds to requests, you still have to supply a country code for the
- // rule to evaluate. In this case, you configure the rule to only count matching
- // requests, but it will still generate logging and count metrics for any matches.
- // You can reduce the logging and metrics that the rule produces by specifying
- // a country that's unlikely to be a source of traffic to your site.
- CountryCodes []*string `min:"1" type:"list" enum:"CountryCode"`
- // The configuration for inspecting IP addresses in an HTTP header that you
- // specify, instead of using the IP address that's reported by the web request
- // origin. Commonly, this is the X-Forwarded-For (XFF) header, but you can specify
- // any header name.
- //
- // If the specified header isn't present in the request, WAF doesn't apply the
- // rule to the web request at all.
- ForwardedIPConfig *ForwardedIPConfig `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GeoMatchStatement) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GeoMatchStatement) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *GeoMatchStatement) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "GeoMatchStatement"}
- if s.CountryCodes != nil && len(s.CountryCodes) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("CountryCodes", 1))
- }
- if s.ForwardedIPConfig != nil {
- if err := s.ForwardedIPConfig.Validate(); err != nil {
- invalidParams.AddNested("ForwardedIPConfig", err.(request.ErrInvalidParams))
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetCountryCodes sets the CountryCodes field's value.
- func (s *GeoMatchStatement) SetCountryCodes(v []*string) *GeoMatchStatement {
- s.CountryCodes = v
- return s
- }
- // SetForwardedIPConfig sets the ForwardedIPConfig field's value.
- func (s *GeoMatchStatement) SetForwardedIPConfig(v *ForwardedIPConfig) *GeoMatchStatement {
- s.ForwardedIPConfig = v
- return s
- }
- type GetIPSetInput struct {
- _ struct{} `type:"structure"`
- // A unique identifier for the set. This ID is returned in the responses to
- // create and list commands. You provide it to operations like update and delete.
- //
- // Id is a required field
- Id *string `min:"1" type:"string" required:"true"`
- // The name of the IP set. You cannot change the name of an IPSet after you
- // create it.
- //
- // Name is a required field
- Name *string `min:"1" type:"string" required:"true"`
- // Specifies whether this is for an Amazon CloudFront distribution or for a
- // regional application. A regional application can be an Application Load Balancer
- // (ALB), an Amazon API Gateway REST API, an AppSync GraphQL API, or an Amazon
- // Cognito user pool.
- //
- // To work with CloudFront, you must also specify the Region US East (N. Virginia)
- // as follows:
- //
- // * CLI - Specify the Region when you use the CloudFront scope: --scope=CLOUDFRONT
- // --region=us-east-1.
- //
- // * API and SDKs - For all calls, use the Region endpoint us-east-1.
- //
- // Scope is a required field
- Scope *string `type:"string" required:"true" enum:"Scope"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetIPSetInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetIPSetInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *GetIPSetInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "GetIPSetInput"}
- if s.Id == nil {
- invalidParams.Add(request.NewErrParamRequired("Id"))
- }
- if s.Id != nil && len(*s.Id) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Id", 1))
- }
- if s.Name == nil {
- invalidParams.Add(request.NewErrParamRequired("Name"))
- }
- if s.Name != nil && len(*s.Name) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Name", 1))
- }
- if s.Scope == nil {
- invalidParams.Add(request.NewErrParamRequired("Scope"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetId sets the Id field's value.
- func (s *GetIPSetInput) SetId(v string) *GetIPSetInput {
- s.Id = &v
- return s
- }
- // SetName sets the Name field's value.
- func (s *GetIPSetInput) SetName(v string) *GetIPSetInput {
- s.Name = &v
- return s
- }
- // SetScope sets the Scope field's value.
- func (s *GetIPSetInput) SetScope(v string) *GetIPSetInput {
- s.Scope = &v
- return s
- }
- type GetIPSetOutput struct {
- _ struct{} `type:"structure"`
- // Contains zero or more IP addresses or blocks of IP addresses specified in
- // Classless Inter-Domain Routing (CIDR) notation. WAF supports all IPv4 and
- // IPv6 CIDR ranges except for /0. For information about CIDR notation, see
- // the Wikipedia entry Classless Inter-Domain Routing (https://en.wikipedia.org/wiki/Classless_Inter-Domain_Routing).
- //
- // WAF assigns an ARN to each IPSet that you create. To use an IP set in a rule,
- // you provide the ARN to the Rule statement IPSetReferenceStatement.
- IPSet *IPSet `type:"structure"`
- // A token used for optimistic locking. WAF returns a token to your get and
- // list requests, to mark the state of the entity at the time of the request.
- // To make changes to the entity associated with the token, you provide the
- // token to operations like update and delete. WAF uses the token to ensure
- // that no changes have been made to the entity since you last retrieved it.
- // If a change has been made, the update fails with a WAFOptimisticLockException.
- // If this happens, perform another get, and use the new token returned by that
- // operation.
- LockToken *string `min:"1" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetIPSetOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetIPSetOutput) GoString() string {
- return s.String()
- }
- // SetIPSet sets the IPSet field's value.
- func (s *GetIPSetOutput) SetIPSet(v *IPSet) *GetIPSetOutput {
- s.IPSet = v
- return s
- }
- // SetLockToken sets the LockToken field's value.
- func (s *GetIPSetOutput) SetLockToken(v string) *GetIPSetOutput {
- s.LockToken = &v
- return s
- }
- type GetLoggingConfigurationInput struct {
- _ struct{} `type:"structure"`
- // The Amazon Resource Name (ARN) of the web ACL for which you want to get the
- // LoggingConfiguration.
- //
- // ResourceArn is a required field
- ResourceArn *string `min:"20" type:"string" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetLoggingConfigurationInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetLoggingConfigurationInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *GetLoggingConfigurationInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "GetLoggingConfigurationInput"}
- if s.ResourceArn == nil {
- invalidParams.Add(request.NewErrParamRequired("ResourceArn"))
- }
- if s.ResourceArn != nil && len(*s.ResourceArn) < 20 {
- invalidParams.Add(request.NewErrParamMinLen("ResourceArn", 20))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetResourceArn sets the ResourceArn field's value.
- func (s *GetLoggingConfigurationInput) SetResourceArn(v string) *GetLoggingConfigurationInput {
- s.ResourceArn = &v
- return s
- }
- type GetLoggingConfigurationOutput struct {
- _ struct{} `type:"structure"`
- // The LoggingConfiguration for the specified web ACL.
- LoggingConfiguration *LoggingConfiguration `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetLoggingConfigurationOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetLoggingConfigurationOutput) GoString() string {
- return s.String()
- }
- // SetLoggingConfiguration sets the LoggingConfiguration field's value.
- func (s *GetLoggingConfigurationOutput) SetLoggingConfiguration(v *LoggingConfiguration) *GetLoggingConfigurationOutput {
- s.LoggingConfiguration = v
- return s
- }
- type GetManagedRuleSetInput struct {
- _ struct{} `type:"structure"`
- // A unique identifier for the managed rule set. The ID is returned in the responses
- // to commands like list. You provide it to operations like get and update.
- //
- // Id is a required field
- Id *string `min:"1" type:"string" required:"true"`
- // The name of the managed rule set. You use this, along with the rule set ID,
- // to identify the rule set.
- //
- // This name is assigned to the corresponding managed rule group, which your
- // customers can access and use.
- //
- // Name is a required field
- Name *string `min:"1" type:"string" required:"true"`
- // Specifies whether this is for an Amazon CloudFront distribution or for a
- // regional application. A regional application can be an Application Load Balancer
- // (ALB), an Amazon API Gateway REST API, an AppSync GraphQL API, or an Amazon
- // Cognito user pool.
- //
- // To work with CloudFront, you must also specify the Region US East (N. Virginia)
- // as follows:
- //
- // * CLI - Specify the Region when you use the CloudFront scope: --scope=CLOUDFRONT
- // --region=us-east-1.
- //
- // * API and SDKs - For all calls, use the Region endpoint us-east-1.
- //
- // Scope is a required field
- Scope *string `type:"string" required:"true" enum:"Scope"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetManagedRuleSetInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetManagedRuleSetInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *GetManagedRuleSetInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "GetManagedRuleSetInput"}
- if s.Id == nil {
- invalidParams.Add(request.NewErrParamRequired("Id"))
- }
- if s.Id != nil && len(*s.Id) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Id", 1))
- }
- if s.Name == nil {
- invalidParams.Add(request.NewErrParamRequired("Name"))
- }
- if s.Name != nil && len(*s.Name) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Name", 1))
- }
- if s.Scope == nil {
- invalidParams.Add(request.NewErrParamRequired("Scope"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetId sets the Id field's value.
- func (s *GetManagedRuleSetInput) SetId(v string) *GetManagedRuleSetInput {
- s.Id = &v
- return s
- }
- // SetName sets the Name field's value.
- func (s *GetManagedRuleSetInput) SetName(v string) *GetManagedRuleSetInput {
- s.Name = &v
- return s
- }
- // SetScope sets the Scope field's value.
- func (s *GetManagedRuleSetInput) SetScope(v string) *GetManagedRuleSetInput {
- s.Scope = &v
- return s
- }
- type GetManagedRuleSetOutput struct {
- _ struct{} `type:"structure"`
- // A token used for optimistic locking. WAF returns a token to your get and
- // list requests, to mark the state of the entity at the time of the request.
- // To make changes to the entity associated with the token, you provide the
- // token to operations like update and delete. WAF uses the token to ensure
- // that no changes have been made to the entity since you last retrieved it.
- // If a change has been made, the update fails with a WAFOptimisticLockException.
- // If this happens, perform another get, and use the new token returned by that
- // operation.
- LockToken *string `min:"1" type:"string"`
- // The managed rule set that you requested.
- ManagedRuleSet *ManagedRuleSet `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetManagedRuleSetOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetManagedRuleSetOutput) GoString() string {
- return s.String()
- }
- // SetLockToken sets the LockToken field's value.
- func (s *GetManagedRuleSetOutput) SetLockToken(v string) *GetManagedRuleSetOutput {
- s.LockToken = &v
- return s
- }
- // SetManagedRuleSet sets the ManagedRuleSet field's value.
- func (s *GetManagedRuleSetOutput) SetManagedRuleSet(v *ManagedRuleSet) *GetManagedRuleSetOutput {
- s.ManagedRuleSet = v
- return s
- }
- type GetMobileSdkReleaseInput struct {
- _ struct{} `type:"structure"`
- // The device platform.
- //
- // Platform is a required field
- Platform *string `type:"string" required:"true" enum:"Platform"`
- // The release version. For the latest available version, specify LATEST.
- //
- // ReleaseVersion is a required field
- ReleaseVersion *string `min:"1" type:"string" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetMobileSdkReleaseInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetMobileSdkReleaseInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *GetMobileSdkReleaseInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "GetMobileSdkReleaseInput"}
- if s.Platform == nil {
- invalidParams.Add(request.NewErrParamRequired("Platform"))
- }
- if s.ReleaseVersion == nil {
- invalidParams.Add(request.NewErrParamRequired("ReleaseVersion"))
- }
- if s.ReleaseVersion != nil && len(*s.ReleaseVersion) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("ReleaseVersion", 1))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetPlatform sets the Platform field's value.
- func (s *GetMobileSdkReleaseInput) SetPlatform(v string) *GetMobileSdkReleaseInput {
- s.Platform = &v
- return s
- }
- // SetReleaseVersion sets the ReleaseVersion field's value.
- func (s *GetMobileSdkReleaseInput) SetReleaseVersion(v string) *GetMobileSdkReleaseInput {
- s.ReleaseVersion = &v
- return s
- }
- type GetMobileSdkReleaseOutput struct {
- _ struct{} `type:"structure"`
- // Information for a specified SDK release, including release notes and tags.
- MobileSdkRelease *MobileSdkRelease `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetMobileSdkReleaseOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetMobileSdkReleaseOutput) GoString() string {
- return s.String()
- }
- // SetMobileSdkRelease sets the MobileSdkRelease field's value.
- func (s *GetMobileSdkReleaseOutput) SetMobileSdkRelease(v *MobileSdkRelease) *GetMobileSdkReleaseOutput {
- s.MobileSdkRelease = v
- return s
- }
- type GetPermissionPolicyInput struct {
- _ struct{} `type:"structure"`
- // The Amazon Resource Name (ARN) of the rule group for which you want to get
- // the policy.
- //
- // ResourceArn is a required field
- ResourceArn *string `min:"20" type:"string" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetPermissionPolicyInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetPermissionPolicyInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *GetPermissionPolicyInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "GetPermissionPolicyInput"}
- if s.ResourceArn == nil {
- invalidParams.Add(request.NewErrParamRequired("ResourceArn"))
- }
- if s.ResourceArn != nil && len(*s.ResourceArn) < 20 {
- invalidParams.Add(request.NewErrParamMinLen("ResourceArn", 20))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetResourceArn sets the ResourceArn field's value.
- func (s *GetPermissionPolicyInput) SetResourceArn(v string) *GetPermissionPolicyInput {
- s.ResourceArn = &v
- return s
- }
- type GetPermissionPolicyOutput struct {
- _ struct{} `type:"structure"`
- // The IAM policy that is attached to the specified rule group.
- Policy *string `min:"1" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetPermissionPolicyOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetPermissionPolicyOutput) GoString() string {
- return s.String()
- }
- // SetPolicy sets the Policy field's value.
- func (s *GetPermissionPolicyOutput) SetPolicy(v string) *GetPermissionPolicyOutput {
- s.Policy = &v
- return s
- }
- type GetRateBasedStatementManagedKeysInput struct {
- _ struct{} `type:"structure"`
- // The name of the rule group reference statement in your web ACL. This is required
- // only when you have the rate-based rule nested inside a rule group.
- RuleGroupRuleName *string `min:"1" type:"string"`
- // The name of the rate-based rule to get the keys for. If you have the rule
- // defined inside a rule group that you're using in your web ACL, also provide
- // the name of the rule group reference statement in the request parameter RuleGroupRuleName.
- //
- // RuleName is a required field
- RuleName *string `min:"1" type:"string" required:"true"`
- // Specifies whether this is for an Amazon CloudFront distribution or for a
- // regional application. A regional application can be an Application Load Balancer
- // (ALB), an Amazon API Gateway REST API, an AppSync GraphQL API, or an Amazon
- // Cognito user pool.
- //
- // To work with CloudFront, you must also specify the Region US East (N. Virginia)
- // as follows:
- //
- // * CLI - Specify the Region when you use the CloudFront scope: --scope=CLOUDFRONT
- // --region=us-east-1.
- //
- // * API and SDKs - For all calls, use the Region endpoint us-east-1.
- //
- // Scope is a required field
- Scope *string `type:"string" required:"true" enum:"Scope"`
- // The unique identifier for the web ACL. This ID is returned in the responses
- // to create and list commands. You provide it to operations like update and
- // delete.
- //
- // WebACLId is a required field
- WebACLId *string `min:"1" type:"string" required:"true"`
- // The name of the web ACL. You cannot change the name of a web ACL after you
- // create it.
- //
- // WebACLName is a required field
- WebACLName *string `min:"1" type:"string" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetRateBasedStatementManagedKeysInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetRateBasedStatementManagedKeysInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *GetRateBasedStatementManagedKeysInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "GetRateBasedStatementManagedKeysInput"}
- if s.RuleGroupRuleName != nil && len(*s.RuleGroupRuleName) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("RuleGroupRuleName", 1))
- }
- if s.RuleName == nil {
- invalidParams.Add(request.NewErrParamRequired("RuleName"))
- }
- if s.RuleName != nil && len(*s.RuleName) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("RuleName", 1))
- }
- if s.Scope == nil {
- invalidParams.Add(request.NewErrParamRequired("Scope"))
- }
- if s.WebACLId == nil {
- invalidParams.Add(request.NewErrParamRequired("WebACLId"))
- }
- if s.WebACLId != nil && len(*s.WebACLId) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("WebACLId", 1))
- }
- if s.WebACLName == nil {
- invalidParams.Add(request.NewErrParamRequired("WebACLName"))
- }
- if s.WebACLName != nil && len(*s.WebACLName) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("WebACLName", 1))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetRuleGroupRuleName sets the RuleGroupRuleName field's value.
- func (s *GetRateBasedStatementManagedKeysInput) SetRuleGroupRuleName(v string) *GetRateBasedStatementManagedKeysInput {
- s.RuleGroupRuleName = &v
- return s
- }
- // SetRuleName sets the RuleName field's value.
- func (s *GetRateBasedStatementManagedKeysInput) SetRuleName(v string) *GetRateBasedStatementManagedKeysInput {
- s.RuleName = &v
- return s
- }
- // SetScope sets the Scope field's value.
- func (s *GetRateBasedStatementManagedKeysInput) SetScope(v string) *GetRateBasedStatementManagedKeysInput {
- s.Scope = &v
- return s
- }
- // SetWebACLId sets the WebACLId field's value.
- func (s *GetRateBasedStatementManagedKeysInput) SetWebACLId(v string) *GetRateBasedStatementManagedKeysInput {
- s.WebACLId = &v
- return s
- }
- // SetWebACLName sets the WebACLName field's value.
- func (s *GetRateBasedStatementManagedKeysInput) SetWebACLName(v string) *GetRateBasedStatementManagedKeysInput {
- s.WebACLName = &v
- return s
- }
- type GetRateBasedStatementManagedKeysOutput struct {
- _ struct{} `type:"structure"`
- // The keys that are of Internet Protocol version 4 (IPv4).
- ManagedKeysIPV4 *RateBasedStatementManagedKeysIPSet `type:"structure"`
- // The keys that are of Internet Protocol version 6 (IPv6).
- ManagedKeysIPV6 *RateBasedStatementManagedKeysIPSet `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetRateBasedStatementManagedKeysOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetRateBasedStatementManagedKeysOutput) GoString() string {
- return s.String()
- }
- // SetManagedKeysIPV4 sets the ManagedKeysIPV4 field's value.
- func (s *GetRateBasedStatementManagedKeysOutput) SetManagedKeysIPV4(v *RateBasedStatementManagedKeysIPSet) *GetRateBasedStatementManagedKeysOutput {
- s.ManagedKeysIPV4 = v
- return s
- }
- // SetManagedKeysIPV6 sets the ManagedKeysIPV6 field's value.
- func (s *GetRateBasedStatementManagedKeysOutput) SetManagedKeysIPV6(v *RateBasedStatementManagedKeysIPSet) *GetRateBasedStatementManagedKeysOutput {
- s.ManagedKeysIPV6 = v
- return s
- }
- type GetRegexPatternSetInput struct {
- _ struct{} `type:"structure"`
- // A unique identifier for the set. This ID is returned in the responses to
- // create and list commands. You provide it to operations like update and delete.
- //
- // Id is a required field
- Id *string `min:"1" type:"string" required:"true"`
- // The name of the set. You cannot change the name after you create the set.
- //
- // Name is a required field
- Name *string `min:"1" type:"string" required:"true"`
- // Specifies whether this is for an Amazon CloudFront distribution or for a
- // regional application. A regional application can be an Application Load Balancer
- // (ALB), an Amazon API Gateway REST API, an AppSync GraphQL API, or an Amazon
- // Cognito user pool.
- //
- // To work with CloudFront, you must also specify the Region US East (N. Virginia)
- // as follows:
- //
- // * CLI - Specify the Region when you use the CloudFront scope: --scope=CLOUDFRONT
- // --region=us-east-1.
- //
- // * API and SDKs - For all calls, use the Region endpoint us-east-1.
- //
- // Scope is a required field
- Scope *string `type:"string" required:"true" enum:"Scope"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetRegexPatternSetInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetRegexPatternSetInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *GetRegexPatternSetInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "GetRegexPatternSetInput"}
- if s.Id == nil {
- invalidParams.Add(request.NewErrParamRequired("Id"))
- }
- if s.Id != nil && len(*s.Id) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Id", 1))
- }
- if s.Name == nil {
- invalidParams.Add(request.NewErrParamRequired("Name"))
- }
- if s.Name != nil && len(*s.Name) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Name", 1))
- }
- if s.Scope == nil {
- invalidParams.Add(request.NewErrParamRequired("Scope"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetId sets the Id field's value.
- func (s *GetRegexPatternSetInput) SetId(v string) *GetRegexPatternSetInput {
- s.Id = &v
- return s
- }
- // SetName sets the Name field's value.
- func (s *GetRegexPatternSetInput) SetName(v string) *GetRegexPatternSetInput {
- s.Name = &v
- return s
- }
- // SetScope sets the Scope field's value.
- func (s *GetRegexPatternSetInput) SetScope(v string) *GetRegexPatternSetInput {
- s.Scope = &v
- return s
- }
- type GetRegexPatternSetOutput struct {
- _ struct{} `type:"structure"`
- // A token used for optimistic locking. WAF returns a token to your get and
- // list requests, to mark the state of the entity at the time of the request.
- // To make changes to the entity associated with the token, you provide the
- // token to operations like update and delete. WAF uses the token to ensure
- // that no changes have been made to the entity since you last retrieved it.
- // If a change has been made, the update fails with a WAFOptimisticLockException.
- // If this happens, perform another get, and use the new token returned by that
- // operation.
- LockToken *string `min:"1" type:"string"`
- // Contains one or more regular expressions.
- //
- // WAF assigns an ARN to each RegexPatternSet that you create. To use a set
- // in a rule, you provide the ARN to the Rule statement RegexPatternSetReferenceStatement.
- RegexPatternSet *RegexPatternSet `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetRegexPatternSetOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetRegexPatternSetOutput) GoString() string {
- return s.String()
- }
- // SetLockToken sets the LockToken field's value.
- func (s *GetRegexPatternSetOutput) SetLockToken(v string) *GetRegexPatternSetOutput {
- s.LockToken = &v
- return s
- }
- // SetRegexPatternSet sets the RegexPatternSet field's value.
- func (s *GetRegexPatternSetOutput) SetRegexPatternSet(v *RegexPatternSet) *GetRegexPatternSetOutput {
- s.RegexPatternSet = v
- return s
- }
- type GetRuleGroupInput struct {
- _ struct{} `type:"structure"`
- // The Amazon Resource Name (ARN) of the entity.
- ARN *string `min:"20" type:"string"`
- // A unique identifier for the rule group. This ID is returned in the responses
- // to create and list commands. You provide it to operations like update and
- // delete.
- Id *string `min:"1" type:"string"`
- // The name of the rule group. You cannot change the name of a rule group after
- // you create it.
- Name *string `min:"1" type:"string"`
- // Specifies whether this is for an Amazon CloudFront distribution or for a
- // regional application. A regional application can be an Application Load Balancer
- // (ALB), an Amazon API Gateway REST API, an AppSync GraphQL API, or an Amazon
- // Cognito user pool.
- //
- // To work with CloudFront, you must also specify the Region US East (N. Virginia)
- // as follows:
- //
- // * CLI - Specify the Region when you use the CloudFront scope: --scope=CLOUDFRONT
- // --region=us-east-1.
- //
- // * API and SDKs - For all calls, use the Region endpoint us-east-1.
- Scope *string `type:"string" enum:"Scope"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetRuleGroupInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetRuleGroupInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *GetRuleGroupInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "GetRuleGroupInput"}
- if s.ARN != nil && len(*s.ARN) < 20 {
- invalidParams.Add(request.NewErrParamMinLen("ARN", 20))
- }
- if s.Id != nil && len(*s.Id) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Id", 1))
- }
- if s.Name != nil && len(*s.Name) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Name", 1))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetARN sets the ARN field's value.
- func (s *GetRuleGroupInput) SetARN(v string) *GetRuleGroupInput {
- s.ARN = &v
- return s
- }
- // SetId sets the Id field's value.
- func (s *GetRuleGroupInput) SetId(v string) *GetRuleGroupInput {
- s.Id = &v
- return s
- }
- // SetName sets the Name field's value.
- func (s *GetRuleGroupInput) SetName(v string) *GetRuleGroupInput {
- s.Name = &v
- return s
- }
- // SetScope sets the Scope field's value.
- func (s *GetRuleGroupInput) SetScope(v string) *GetRuleGroupInput {
- s.Scope = &v
- return s
- }
- type GetRuleGroupOutput struct {
- _ struct{} `type:"structure"`
- // A token used for optimistic locking. WAF returns a token to your get and
- // list requests, to mark the state of the entity at the time of the request.
- // To make changes to the entity associated with the token, you provide the
- // token to operations like update and delete. WAF uses the token to ensure
- // that no changes have been made to the entity since you last retrieved it.
- // If a change has been made, the update fails with a WAFOptimisticLockException.
- // If this happens, perform another get, and use the new token returned by that
- // operation.
- LockToken *string `min:"1" type:"string"`
- // A rule group defines a collection of rules to inspect and control web requests
- // that you can use in a WebACL. When you create a rule group, you define an
- // immutable capacity limit. If you update a rule group, you must stay within
- // the capacity. This allows others to reuse the rule group with confidence
- // in its capacity requirements.
- RuleGroup *RuleGroup `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetRuleGroupOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetRuleGroupOutput) GoString() string {
- return s.String()
- }
- // SetLockToken sets the LockToken field's value.
- func (s *GetRuleGroupOutput) SetLockToken(v string) *GetRuleGroupOutput {
- s.LockToken = &v
- return s
- }
- // SetRuleGroup sets the RuleGroup field's value.
- func (s *GetRuleGroupOutput) SetRuleGroup(v *RuleGroup) *GetRuleGroupOutput {
- s.RuleGroup = v
- return s
- }
- type GetSampledRequestsInput struct {
- _ struct{} `type:"structure"`
- // The number of requests that you want WAF to return from among the first 5,000
- // requests that your Amazon Web Services resource received during the time
- // range. If your resource received fewer requests than the value of MaxItems,
- // GetSampledRequests returns information about all of them.
- //
- // MaxItems is a required field
- MaxItems *int64 `min:"1" type:"long" required:"true"`
- // The metric name assigned to the Rule or RuleGroup dimension for which you
- // want a sample of requests.
- //
- // RuleMetricName is a required field
- RuleMetricName *string `min:"1" type:"string" required:"true"`
- // Specifies whether this is for an Amazon CloudFront distribution or for a
- // regional application. A regional application can be an Application Load Balancer
- // (ALB), an Amazon API Gateway REST API, an AppSync GraphQL API, or an Amazon
- // Cognito user pool.
- //
- // To work with CloudFront, you must also specify the Region US East (N. Virginia)
- // as follows:
- //
- // * CLI - Specify the Region when you use the CloudFront scope: --scope=CLOUDFRONT
- // --region=us-east-1.
- //
- // * API and SDKs - For all calls, use the Region endpoint us-east-1.
- //
- // Scope is a required field
- Scope *string `type:"string" required:"true" enum:"Scope"`
- // The start date and time and the end date and time of the range for which
- // you want GetSampledRequests to return a sample of requests. You must specify
- // the times in Coordinated Universal Time (UTC) format. UTC format includes
- // the special designator, Z. For example, "2016-09-27T14:50Z". You can specify
- // any time range in the previous three hours. If you specify a start time that's
- // earlier than three hours ago, WAF sets it to three hours ago.
- //
- // TimeWindow is a required field
- TimeWindow *TimeWindow `type:"structure" required:"true"`
- // The Amazon resource name (ARN) of the WebACL for which you want a sample
- // of requests.
- //
- // WebAclArn is a required field
- WebAclArn *string `min:"20" type:"string" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetSampledRequestsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetSampledRequestsInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *GetSampledRequestsInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "GetSampledRequestsInput"}
- if s.MaxItems == nil {
- invalidParams.Add(request.NewErrParamRequired("MaxItems"))
- }
- if s.MaxItems != nil && *s.MaxItems < 1 {
- invalidParams.Add(request.NewErrParamMinValue("MaxItems", 1))
- }
- if s.RuleMetricName == nil {
- invalidParams.Add(request.NewErrParamRequired("RuleMetricName"))
- }
- if s.RuleMetricName != nil && len(*s.RuleMetricName) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("RuleMetricName", 1))
- }
- if s.Scope == nil {
- invalidParams.Add(request.NewErrParamRequired("Scope"))
- }
- if s.TimeWindow == nil {
- invalidParams.Add(request.NewErrParamRequired("TimeWindow"))
- }
- if s.WebAclArn == nil {
- invalidParams.Add(request.NewErrParamRequired("WebAclArn"))
- }
- if s.WebAclArn != nil && len(*s.WebAclArn) < 20 {
- invalidParams.Add(request.NewErrParamMinLen("WebAclArn", 20))
- }
- if s.TimeWindow != nil {
- if err := s.TimeWindow.Validate(); err != nil {
- invalidParams.AddNested("TimeWindow", err.(request.ErrInvalidParams))
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetMaxItems sets the MaxItems field's value.
- func (s *GetSampledRequestsInput) SetMaxItems(v int64) *GetSampledRequestsInput {
- s.MaxItems = &v
- return s
- }
- // SetRuleMetricName sets the RuleMetricName field's value.
- func (s *GetSampledRequestsInput) SetRuleMetricName(v string) *GetSampledRequestsInput {
- s.RuleMetricName = &v
- return s
- }
- // SetScope sets the Scope field's value.
- func (s *GetSampledRequestsInput) SetScope(v string) *GetSampledRequestsInput {
- s.Scope = &v
- return s
- }
- // SetTimeWindow sets the TimeWindow field's value.
- func (s *GetSampledRequestsInput) SetTimeWindow(v *TimeWindow) *GetSampledRequestsInput {
- s.TimeWindow = v
- return s
- }
- // SetWebAclArn sets the WebAclArn field's value.
- func (s *GetSampledRequestsInput) SetWebAclArn(v string) *GetSampledRequestsInput {
- s.WebAclArn = &v
- return s
- }
- type GetSampledRequestsOutput struct {
- _ struct{} `type:"structure"`
- // The total number of requests from which GetSampledRequests got a sample of
- // MaxItems requests. If PopulationSize is less than MaxItems, the sample includes
- // every request that your Amazon Web Services resource received during the
- // specified time range.
- PopulationSize *int64 `type:"long"`
- // A complex type that contains detailed information about each of the requests
- // in the sample.
- SampledRequests []*SampledHTTPRequest `type:"list"`
- // Usually, TimeWindow is the time range that you specified in the GetSampledRequests
- // request. However, if your Amazon Web Services resource received more than
- // 5,000 requests during the time range that you specified in the request, GetSampledRequests
- // returns the time range for the first 5,000 requests. Times are in Coordinated
- // Universal Time (UTC) format.
- TimeWindow *TimeWindow `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetSampledRequestsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetSampledRequestsOutput) GoString() string {
- return s.String()
- }
- // SetPopulationSize sets the PopulationSize field's value.
- func (s *GetSampledRequestsOutput) SetPopulationSize(v int64) *GetSampledRequestsOutput {
- s.PopulationSize = &v
- return s
- }
- // SetSampledRequests sets the SampledRequests field's value.
- func (s *GetSampledRequestsOutput) SetSampledRequests(v []*SampledHTTPRequest) *GetSampledRequestsOutput {
- s.SampledRequests = v
- return s
- }
- // SetTimeWindow sets the TimeWindow field's value.
- func (s *GetSampledRequestsOutput) SetTimeWindow(v *TimeWindow) *GetSampledRequestsOutput {
- s.TimeWindow = v
- return s
- }
- type GetWebACLForResourceInput struct {
- _ struct{} `type:"structure"`
- // The Amazon Resource Name (ARN) of the resource whose web ACL you want to
- // retrieve.
- //
- // The ARN must be in one of the following formats:
- //
- // * For an Application Load Balancer: arn:aws:elasticloadbalancing:region:account-id:loadbalancer/app/load-balancer-name/load-balancer-id
- //
- // * For an Amazon API Gateway REST API: arn:aws:apigateway:region::/restapis/api-id/stages/stage-name
- //
- // * For an AppSync GraphQL API: arn:aws:appsync:region:account-id:apis/GraphQLApiId
- //
- // * For an Amazon Cognito user pool: arn:aws:cognito-idp:region:account-id:userpool/user-pool-id
- //
- // ResourceArn is a required field
- ResourceArn *string `min:"20" type:"string" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetWebACLForResourceInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetWebACLForResourceInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *GetWebACLForResourceInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "GetWebACLForResourceInput"}
- if s.ResourceArn == nil {
- invalidParams.Add(request.NewErrParamRequired("ResourceArn"))
- }
- if s.ResourceArn != nil && len(*s.ResourceArn) < 20 {
- invalidParams.Add(request.NewErrParamMinLen("ResourceArn", 20))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetResourceArn sets the ResourceArn field's value.
- func (s *GetWebACLForResourceInput) SetResourceArn(v string) *GetWebACLForResourceInput {
- s.ResourceArn = &v
- return s
- }
- type GetWebACLForResourceOutput struct {
- _ struct{} `type:"structure"`
- // The web ACL that is associated with the resource. If there is no associated
- // resource, WAF returns a null web ACL.
- WebACL *WebACL `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetWebACLForResourceOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetWebACLForResourceOutput) GoString() string {
- return s.String()
- }
- // SetWebACL sets the WebACL field's value.
- func (s *GetWebACLForResourceOutput) SetWebACL(v *WebACL) *GetWebACLForResourceOutput {
- s.WebACL = v
- return s
- }
- type GetWebACLInput struct {
- _ struct{} `type:"structure"`
- // The unique identifier for the web ACL. This ID is returned in the responses
- // to create and list commands. You provide it to operations like update and
- // delete.
- //
- // Id is a required field
- Id *string `min:"1" type:"string" required:"true"`
- // The name of the web ACL. You cannot change the name of a web ACL after you
- // create it.
- //
- // Name is a required field
- Name *string `min:"1" type:"string" required:"true"`
- // Specifies whether this is for an Amazon CloudFront distribution or for a
- // regional application. A regional application can be an Application Load Balancer
- // (ALB), an Amazon API Gateway REST API, an AppSync GraphQL API, or an Amazon
- // Cognito user pool.
- //
- // To work with CloudFront, you must also specify the Region US East (N. Virginia)
- // as follows:
- //
- // * CLI - Specify the Region when you use the CloudFront scope: --scope=CLOUDFRONT
- // --region=us-east-1.
- //
- // * API and SDKs - For all calls, use the Region endpoint us-east-1.
- //
- // Scope is a required field
- Scope *string `type:"string" required:"true" enum:"Scope"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetWebACLInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetWebACLInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *GetWebACLInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "GetWebACLInput"}
- if s.Id == nil {
- invalidParams.Add(request.NewErrParamRequired("Id"))
- }
- if s.Id != nil && len(*s.Id) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Id", 1))
- }
- if s.Name == nil {
- invalidParams.Add(request.NewErrParamRequired("Name"))
- }
- if s.Name != nil && len(*s.Name) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Name", 1))
- }
- if s.Scope == nil {
- invalidParams.Add(request.NewErrParamRequired("Scope"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetId sets the Id field's value.
- func (s *GetWebACLInput) SetId(v string) *GetWebACLInput {
- s.Id = &v
- return s
- }
- // SetName sets the Name field's value.
- func (s *GetWebACLInput) SetName(v string) *GetWebACLInput {
- s.Name = &v
- return s
- }
- // SetScope sets the Scope field's value.
- func (s *GetWebACLInput) SetScope(v string) *GetWebACLInput {
- s.Scope = &v
- return s
- }
- type GetWebACLOutput struct {
- _ struct{} `type:"structure"`
- // The URL to use in SDK integrations with Amazon Web Services managed rule
- // groups. For example, you can use the integration SDKs with the account takeover
- // prevention managed rule group AWSManagedRulesATPRuleSet. This is only populated
- // if you are using a rule group in your web ACL that integrates with your applications
- // in this way. For more information, see WAF client application integration
- // (https://docs.aws.amazon.com/waf/latest/developerguide/waf-application-integration.html)
- // in the WAF Developer Guide.
- ApplicationIntegrationURL *string `type:"string"`
- // A token used for optimistic locking. WAF returns a token to your get and
- // list requests, to mark the state of the entity at the time of the request.
- // To make changes to the entity associated with the token, you provide the
- // token to operations like update and delete. WAF uses the token to ensure
- // that no changes have been made to the entity since you last retrieved it.
- // If a change has been made, the update fails with a WAFOptimisticLockException.
- // If this happens, perform another get, and use the new token returned by that
- // operation.
- LockToken *string `min:"1" type:"string"`
- // The web ACL specification. You can modify the settings in this web ACL and
- // use it to update this web ACL or create a new one.
- WebACL *WebACL `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetWebACLOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s GetWebACLOutput) GoString() string {
- return s.String()
- }
- // SetApplicationIntegrationURL sets the ApplicationIntegrationURL field's value.
- func (s *GetWebACLOutput) SetApplicationIntegrationURL(v string) *GetWebACLOutput {
- s.ApplicationIntegrationURL = &v
- return s
- }
- // SetLockToken sets the LockToken field's value.
- func (s *GetWebACLOutput) SetLockToken(v string) *GetWebACLOutput {
- s.LockToken = &v
- return s
- }
- // SetWebACL sets the WebACL field's value.
- func (s *GetWebACLOutput) SetWebACL(v *WebACL) *GetWebACLOutput {
- s.WebACL = v
- return s
- }
- // Part of the response from GetSampledRequests. This is a complex type that
- // appears as Headers in the response syntax. HTTPHeader contains the names
- // and values of all of the headers that appear in one of the web requests.
- type HTTPHeader struct {
- _ struct{} `type:"structure"`
- // The name of the HTTP header.
- Name *string `type:"string"`
- // The value of the HTTP header.
- Value *string `type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s HTTPHeader) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s HTTPHeader) GoString() string {
- return s.String()
- }
- // SetName sets the Name field's value.
- func (s *HTTPHeader) SetName(v string) *HTTPHeader {
- s.Name = &v
- return s
- }
- // SetValue sets the Value field's value.
- func (s *HTTPHeader) SetValue(v string) *HTTPHeader {
- s.Value = &v
- return s
- }
- // Part of the response from GetSampledRequests. This is a complex type that
- // appears as Request in the response syntax. HTTPRequest contains information
- // about one of the web requests.
- type HTTPRequest struct {
- _ struct{} `type:"structure"`
- // The IP address that the request originated from. If the web ACL is associated
- // with a CloudFront distribution, this is the value of one of the following
- // fields in CloudFront access logs:
- //
- // * c-ip, if the viewer did not use an HTTP proxy or a load balancer to
- // send the request
- //
- // * x-forwarded-for, if the viewer did use an HTTP proxy or a load balancer
- // to send the request
- ClientIP *string `type:"string"`
- // The two-letter country code for the country that the request originated from.
- // For a current list of country codes, see the Wikipedia entry ISO 3166-1 alpha-2
- // (https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2).
- Country *string `type:"string"`
- // The HTTP version specified in the sampled web request, for example, HTTP/1.1.
- HTTPVersion *string `type:"string"`
- // A complex type that contains the name and value for each header in the sampled
- // web request.
- Headers []*HTTPHeader `type:"list"`
- // The HTTP method specified in the sampled web request.
- Method *string `type:"string"`
- // The URI path of the request, which identifies the resource, for example,
- // /images/daily-ad.jpg.
- URI *string `type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s HTTPRequest) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s HTTPRequest) GoString() string {
- return s.String()
- }
- // SetClientIP sets the ClientIP field's value.
- func (s *HTTPRequest) SetClientIP(v string) *HTTPRequest {
- s.ClientIP = &v
- return s
- }
- // SetCountry sets the Country field's value.
- func (s *HTTPRequest) SetCountry(v string) *HTTPRequest {
- s.Country = &v
- return s
- }
- // SetHTTPVersion sets the HTTPVersion field's value.
- func (s *HTTPRequest) SetHTTPVersion(v string) *HTTPRequest {
- s.HTTPVersion = &v
- return s
- }
- // SetHeaders sets the Headers field's value.
- func (s *HTTPRequest) SetHeaders(v []*HTTPHeader) *HTTPRequest {
- s.Headers = v
- return s
- }
- // SetMethod sets the Method field's value.
- func (s *HTTPRequest) SetMethod(v string) *HTTPRequest {
- s.Method = &v
- return s
- }
- // SetURI sets the URI field's value.
- func (s *HTTPRequest) SetURI(v string) *HTTPRequest {
- s.URI = &v
- return s
- }
- // The filter to use to identify the subset of headers to inspect in a web request.
- //
- // You must specify exactly one setting: either All, IncludedHeaders, or ExcludedHeaders.
- //
- // Example JSON: "MatchPattern": { "ExcludedHeaders": {"KeyToExclude1", "KeyToExclude2"}
- // }
- type HeaderMatchPattern struct {
- _ struct{} `type:"structure"`
- // Inspect all headers.
- All *All `type:"structure"`
- // Inspect only the headers whose keys don't match any of the strings specified
- // here.
- ExcludedHeaders []*string `min:"1" type:"list"`
- // Inspect only the headers that have a key that matches one of the strings
- // specified here.
- IncludedHeaders []*string `min:"1" type:"list"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s HeaderMatchPattern) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s HeaderMatchPattern) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *HeaderMatchPattern) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "HeaderMatchPattern"}
- if s.ExcludedHeaders != nil && len(s.ExcludedHeaders) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("ExcludedHeaders", 1))
- }
- if s.IncludedHeaders != nil && len(s.IncludedHeaders) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("IncludedHeaders", 1))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetAll sets the All field's value.
- func (s *HeaderMatchPattern) SetAll(v *All) *HeaderMatchPattern {
- s.All = v
- return s
- }
- // SetExcludedHeaders sets the ExcludedHeaders field's value.
- func (s *HeaderMatchPattern) SetExcludedHeaders(v []*string) *HeaderMatchPattern {
- s.ExcludedHeaders = v
- return s
- }
- // SetIncludedHeaders sets the IncludedHeaders field's value.
- func (s *HeaderMatchPattern) SetIncludedHeaders(v []*string) *HeaderMatchPattern {
- s.IncludedHeaders = v
- return s
- }
- // Inspect all headers in the web request. You can specify the parts of the
- // headers to inspect and you can narrow the set of headers to inspect by including
- // or excluding specific keys.
- //
- // This is used to indicate the web request component to inspect, in the FieldToMatch
- // specification.
- //
- // If you want to inspect just the value of a single header, use the SingleHeader
- // FieldToMatch setting instead.
- //
- // Example JSON: "Headers": { "MatchPattern": { "All": {} }, "MatchScope": "KEY",
- // "OversizeHandling": "MATCH" }
- type Headers struct {
- _ struct{} `type:"structure"`
- // The filter to use to identify the subset of headers to inspect in a web request.
- //
- // You must specify exactly one setting: either All, IncludedHeaders, or ExcludedHeaders.
- //
- // Example JSON: "MatchPattern": { "ExcludedHeaders": {"KeyToExclude1", "KeyToExclude2"}
- // }
- //
- // MatchPattern is a required field
- MatchPattern *HeaderMatchPattern `type:"structure" required:"true"`
- // The parts of the headers to match with the rule inspection criteria. If you
- // specify All, WAF inspects both keys and values.
- //
- // MatchScope is a required field
- MatchScope *string `type:"string" required:"true" enum:"MapMatchScope"`
- // What WAF should do if the headers of the request are larger than WAF can
- // inspect. WAF does not support inspecting the entire contents of request headers
- // when they exceed 8 KB (8192 bytes) or 200 total headers. The underlying host
- // service forwards a maximum of 200 headers and at most 8 KB of header contents
- // to WAF.
- //
- // The options for oversize handling are the following:
- //
- // * CONTINUE - Inspect the headers normally, according to the rule inspection
- // criteria.
- //
- // * MATCH - Treat the web request as matching the rule statement. WAF applies
- // the rule action to the request.
- //
- // * NO_MATCH - Treat the web request as not matching the rule statement.
- //
- // OversizeHandling is a required field
- OversizeHandling *string `type:"string" required:"true" enum:"OversizeHandling"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s Headers) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s Headers) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *Headers) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "Headers"}
- if s.MatchPattern == nil {
- invalidParams.Add(request.NewErrParamRequired("MatchPattern"))
- }
- if s.MatchScope == nil {
- invalidParams.Add(request.NewErrParamRequired("MatchScope"))
- }
- if s.OversizeHandling == nil {
- invalidParams.Add(request.NewErrParamRequired("OversizeHandling"))
- }
- if s.MatchPattern != nil {
- if err := s.MatchPattern.Validate(); err != nil {
- invalidParams.AddNested("MatchPattern", err.(request.ErrInvalidParams))
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetMatchPattern sets the MatchPattern field's value.
- func (s *Headers) SetMatchPattern(v *HeaderMatchPattern) *Headers {
- s.MatchPattern = v
- return s
- }
- // SetMatchScope sets the MatchScope field's value.
- func (s *Headers) SetMatchScope(v string) *Headers {
- s.MatchScope = &v
- return s
- }
- // SetOversizeHandling sets the OversizeHandling field's value.
- func (s *Headers) SetOversizeHandling(v string) *Headers {
- s.OversizeHandling = &v
- return s
- }
- // Contains zero or more IP addresses or blocks of IP addresses specified in
- // Classless Inter-Domain Routing (CIDR) notation. WAF supports all IPv4 and
- // IPv6 CIDR ranges except for /0. For information about CIDR notation, see
- // the Wikipedia entry Classless Inter-Domain Routing (https://en.wikipedia.org/wiki/Classless_Inter-Domain_Routing).
- //
- // WAF assigns an ARN to each IPSet that you create. To use an IP set in a rule,
- // you provide the ARN to the Rule statement IPSetReferenceStatement.
- type IPSet struct {
- _ struct{} `type:"structure"`
- // The Amazon Resource Name (ARN) of the entity.
- //
- // ARN is a required field
- ARN *string `min:"20" type:"string" required:"true"`
- // Contains an array of strings that specifies zero or more IP addresses or
- // blocks of IP addresses. All addresses must be specified using Classless Inter-Domain
- // Routing (CIDR) notation. WAF supports all IPv4 and IPv6 CIDR ranges except
- // for /0.
- //
- // Example address strings:
- //
- // * To configure WAF to allow, block, or count requests that originated
- // from the IP address 192.0.2.44, specify 192.0.2.44/32.
- //
- // * To configure WAF to allow, block, or count requests that originated
- // from IP addresses from 192.0.2.0 to 192.0.2.255, specify 192.0.2.0/24.
- //
- // * To configure WAF to allow, block, or count requests that originated
- // from the IP address 1111:0000:0000:0000:0000:0000:0000:0111, specify 1111:0000:0000:0000:0000:0000:0000:0111/128.
- //
- // * To configure WAF to allow, block, or count requests that originated
- // from IP addresses 1111:0000:0000:0000:0000:0000:0000:0000 to 1111:0000:0000:0000:ffff:ffff:ffff:ffff,
- // specify 1111:0000:0000:0000:0000:0000:0000:0000/64.
- //
- // For more information about CIDR notation, see the Wikipedia entry Classless
- // Inter-Domain Routing (https://en.wikipedia.org/wiki/Classless_Inter-Domain_Routing).
- //
- // Example JSON Addresses specifications:
- //
- // * Empty array: "Addresses": []
- //
- // * Array with one address: "Addresses": ["192.0.2.44/32"]
- //
- // * Array with three addresses: "Addresses": ["192.0.2.44/32", "192.0.2.0/24",
- // "192.0.0.0/16"]
- //
- // * INVALID specification: "Addresses": [""] INVALID
- //
- // Addresses is a required field
- Addresses []*string `type:"list" required:"true"`
- // A description of the IP set that helps with identification.
- Description *string `min:"1" type:"string"`
- // The version of the IP addresses, either IPV4 or IPV6.
- //
- // IPAddressVersion is a required field
- IPAddressVersion *string `type:"string" required:"true" enum:"IPAddressVersion"`
- // A unique identifier for the set. This ID is returned in the responses to
- // create and list commands. You provide it to operations like update and delete.
- //
- // Id is a required field
- Id *string `min:"1" type:"string" required:"true"`
- // The name of the IP set. You cannot change the name of an IPSet after you
- // create it.
- //
- // Name is a required field
- Name *string `min:"1" type:"string" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s IPSet) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s IPSet) GoString() string {
- return s.String()
- }
- // SetARN sets the ARN field's value.
- func (s *IPSet) SetARN(v string) *IPSet {
- s.ARN = &v
- return s
- }
- // SetAddresses sets the Addresses field's value.
- func (s *IPSet) SetAddresses(v []*string) *IPSet {
- s.Addresses = v
- return s
- }
- // SetDescription sets the Description field's value.
- func (s *IPSet) SetDescription(v string) *IPSet {
- s.Description = &v
- return s
- }
- // SetIPAddressVersion sets the IPAddressVersion field's value.
- func (s *IPSet) SetIPAddressVersion(v string) *IPSet {
- s.IPAddressVersion = &v
- return s
- }
- // SetId sets the Id field's value.
- func (s *IPSet) SetId(v string) *IPSet {
- s.Id = &v
- return s
- }
- // SetName sets the Name field's value.
- func (s *IPSet) SetName(v string) *IPSet {
- s.Name = &v
- return s
- }
- // The configuration for inspecting IP addresses in an HTTP header that you
- // specify, instead of using the IP address that's reported by the web request
- // origin. Commonly, this is the X-Forwarded-For (XFF) header, but you can specify
- // any header name.
- //
- // If the specified header isn't present in the request, WAF doesn't apply the
- // rule to the web request at all.
- //
- // This configuration is used only for IPSetReferenceStatement. For GeoMatchStatement
- // and RateBasedStatement, use ForwardedIPConfig instead.
- type IPSetForwardedIPConfig struct {
- _ struct{} `type:"structure"`
- // The match status to assign to the web request if the request doesn't have
- // a valid IP address in the specified position.
- //
- // If the specified header isn't present in the request, WAF doesn't apply the
- // rule to the web request at all.
- //
- // You can specify the following fallback behaviors:
- //
- // * MATCH - Treat the web request as matching the rule statement. WAF applies
- // the rule action to the request.
- //
- // * NO_MATCH - Treat the web request as not matching the rule statement.
- //
- // FallbackBehavior is a required field
- FallbackBehavior *string `type:"string" required:"true" enum:"FallbackBehavior"`
- // The name of the HTTP header to use for the IP address. For example, to use
- // the X-Forwarded-For (XFF) header, set this to X-Forwarded-For.
- //
- // If the specified header isn't present in the request, WAF doesn't apply the
- // rule to the web request at all.
- //
- // HeaderName is a required field
- HeaderName *string `min:"1" type:"string" required:"true"`
- // The position in the header to search for the IP address. The header can contain
- // IP addresses of the original client and also of proxies. For example, the
- // header value could be 10.1.1.1, 127.0.0.0, 10.10.10.10 where the first IP
- // address identifies the original client and the rest identify proxies that
- // the request went through.
- //
- // The options for this setting are the following:
- //
- // * FIRST - Inspect the first IP address in the list of IP addresses in
- // the header. This is usually the client's original IP.
- //
- // * LAST - Inspect the last IP address in the list of IP addresses in the
- // header.
- //
- // * ANY - Inspect all IP addresses in the header for a match. If the header
- // contains more than 10 IP addresses, WAF inspects the last 10.
- //
- // Position is a required field
- Position *string `type:"string" required:"true" enum:"ForwardedIPPosition"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s IPSetForwardedIPConfig) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s IPSetForwardedIPConfig) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *IPSetForwardedIPConfig) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "IPSetForwardedIPConfig"}
- if s.FallbackBehavior == nil {
- invalidParams.Add(request.NewErrParamRequired("FallbackBehavior"))
- }
- if s.HeaderName == nil {
- invalidParams.Add(request.NewErrParamRequired("HeaderName"))
- }
- if s.HeaderName != nil && len(*s.HeaderName) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("HeaderName", 1))
- }
- if s.Position == nil {
- invalidParams.Add(request.NewErrParamRequired("Position"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetFallbackBehavior sets the FallbackBehavior field's value.
- func (s *IPSetForwardedIPConfig) SetFallbackBehavior(v string) *IPSetForwardedIPConfig {
- s.FallbackBehavior = &v
- return s
- }
- // SetHeaderName sets the HeaderName field's value.
- func (s *IPSetForwardedIPConfig) SetHeaderName(v string) *IPSetForwardedIPConfig {
- s.HeaderName = &v
- return s
- }
- // SetPosition sets the Position field's value.
- func (s *IPSetForwardedIPConfig) SetPosition(v string) *IPSetForwardedIPConfig {
- s.Position = &v
- return s
- }
- // A rule statement used to detect web requests coming from particular IP addresses
- // or address ranges. To use this, create an IPSet that specifies the addresses
- // you want to detect, then use the ARN of that set in this statement. To create
- // an IP set, see CreateIPSet.
- //
- // Each IP set rule statement references an IP set. You create and maintain
- // the set independent of your rules. This allows you to use the single set
- // in multiple rules. When you update the referenced set, WAF automatically
- // updates all rules that reference it.
- type IPSetReferenceStatement struct {
- _ struct{} `type:"structure"`
- // The Amazon Resource Name (ARN) of the IPSet that this statement references.
- //
- // ARN is a required field
- ARN *string `min:"20" type:"string" required:"true"`
- // The configuration for inspecting IP addresses in an HTTP header that you
- // specify, instead of using the IP address that's reported by the web request
- // origin. Commonly, this is the X-Forwarded-For (XFF) header, but you can specify
- // any header name.
- //
- // If the specified header isn't present in the request, WAF doesn't apply the
- // rule to the web request at all.
- IPSetForwardedIPConfig *IPSetForwardedIPConfig `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s IPSetReferenceStatement) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s IPSetReferenceStatement) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *IPSetReferenceStatement) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "IPSetReferenceStatement"}
- if s.ARN == nil {
- invalidParams.Add(request.NewErrParamRequired("ARN"))
- }
- if s.ARN != nil && len(*s.ARN) < 20 {
- invalidParams.Add(request.NewErrParamMinLen("ARN", 20))
- }
- if s.IPSetForwardedIPConfig != nil {
- if err := s.IPSetForwardedIPConfig.Validate(); err != nil {
- invalidParams.AddNested("IPSetForwardedIPConfig", err.(request.ErrInvalidParams))
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetARN sets the ARN field's value.
- func (s *IPSetReferenceStatement) SetARN(v string) *IPSetReferenceStatement {
- s.ARN = &v
- return s
- }
- // SetIPSetForwardedIPConfig sets the IPSetForwardedIPConfig field's value.
- func (s *IPSetReferenceStatement) SetIPSetForwardedIPConfig(v *IPSetForwardedIPConfig) *IPSetReferenceStatement {
- s.IPSetForwardedIPConfig = v
- return s
- }
- // High-level information about an IPSet, returned by operations like create
- // and list. This provides information like the ID, that you can use to retrieve
- // and manage an IPSet, and the ARN, that you provide to the IPSetReferenceStatement
- // to use the address set in a Rule.
- type IPSetSummary struct {
- _ struct{} `type:"structure"`
- // The Amazon Resource Name (ARN) of the entity.
- ARN *string `min:"20" type:"string"`
- // A description of the IP set that helps with identification.
- Description *string `min:"1" type:"string"`
- // A unique identifier for the set. This ID is returned in the responses to
- // create and list commands. You provide it to operations like update and delete.
- Id *string `min:"1" type:"string"`
- // A token used for optimistic locking. WAF returns a token to your get and
- // list requests, to mark the state of the entity at the time of the request.
- // To make changes to the entity associated with the token, you provide the
- // token to operations like update and delete. WAF uses the token to ensure
- // that no changes have been made to the entity since you last retrieved it.
- // If a change has been made, the update fails with a WAFOptimisticLockException.
- // If this happens, perform another get, and use the new token returned by that
- // operation.
- LockToken *string `min:"1" type:"string"`
- // The name of the IP set. You cannot change the name of an IPSet after you
- // create it.
- Name *string `min:"1" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s IPSetSummary) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s IPSetSummary) GoString() string {
- return s.String()
- }
- // SetARN sets the ARN field's value.
- func (s *IPSetSummary) SetARN(v string) *IPSetSummary {
- s.ARN = &v
- return s
- }
- // SetDescription sets the Description field's value.
- func (s *IPSetSummary) SetDescription(v string) *IPSetSummary {
- s.Description = &v
- return s
- }
- // SetId sets the Id field's value.
- func (s *IPSetSummary) SetId(v string) *IPSetSummary {
- s.Id = &v
- return s
- }
- // SetLockToken sets the LockToken field's value.
- func (s *IPSetSummary) SetLockToken(v string) *IPSetSummary {
- s.LockToken = &v
- return s
- }
- // SetName sets the Name field's value.
- func (s *IPSetSummary) SetName(v string) *IPSetSummary {
- s.Name = &v
- return s
- }
- // Used for CAPTCHA and challenge token settings. Determines how long a CAPTCHA
- // or challenge timestamp remains valid after WAF updates it for a successful
- // CAPTCHA or challenge response.
- type ImmunityTimeProperty struct {
- _ struct{} `type:"structure"`
- // The amount of time, in seconds, that a CAPTCHA or challenge timestamp is
- // considered valid by WAF. The default setting is 300.
- //
- // For the Challenge action, the minimum setting is 300.
- //
- // ImmunityTime is a required field
- ImmunityTime *int64 `min:"60" type:"long" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ImmunityTimeProperty) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ImmunityTimeProperty) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ImmunityTimeProperty) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ImmunityTimeProperty"}
- if s.ImmunityTime == nil {
- invalidParams.Add(request.NewErrParamRequired("ImmunityTime"))
- }
- if s.ImmunityTime != nil && *s.ImmunityTime < 60 {
- invalidParams.Add(request.NewErrParamMinValue("ImmunityTime", 60))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetImmunityTime sets the ImmunityTime field's value.
- func (s *ImmunityTimeProperty) SetImmunityTime(v int64) *ImmunityTimeProperty {
- s.ImmunityTime = &v
- return s
- }
- // Inspect the body of the web request as JSON. The body immediately follows
- // the request headers.
- //
- // This is used to indicate the web request component to inspect, in the FieldToMatch
- // specification.
- //
- // Use the specifications in this object to indicate which parts of the JSON
- // body to inspect using the rule's inspection criteria. WAF inspects only the
- // parts of the JSON that result from the matches that you indicate.
- //
- // Example JSON: "JsonBody": { "MatchPattern": { "All": {} }, "MatchScope":
- // "ALL" }
- type JsonBody struct {
- _ struct{} `type:"structure"`
- // What WAF should do if it fails to completely parse the JSON body. The options
- // are the following:
- //
- // * EVALUATE_AS_STRING - Inspect the body as plain text. WAF applies the
- // text transformations and inspection criteria that you defined for the
- // JSON inspection to the body text string.
- //
- // * MATCH - Treat the web request as matching the rule statement. WAF applies
- // the rule action to the request.
- //
- // * NO_MATCH - Treat the web request as not matching the rule statement.
- //
- // If you don't provide this setting, WAF parses and evaluates the content only
- // up to the first parsing failure that it encounters.
- //
- // WAF does its best to parse the entire JSON body, but might be forced to stop
- // for reasons such as invalid characters, duplicate keys, truncation, and any
- // content whose root node isn't an object or an array.
- //
- // WAF parses the JSON in the following examples as two valid key, value pairs:
- //
- // * Missing comma: {"key1":"value1""key2":"value2"}
- //
- // * Missing colon: {"key1":"value1","key2""value2"}
- //
- // * Extra colons: {"key1"::"value1","key2""value2"}
- InvalidFallbackBehavior *string `type:"string" enum:"BodyParsingFallbackBehavior"`
- // The patterns to look for in the JSON body. WAF inspects the results of these
- // pattern matches against the rule inspection criteria.
- //
- // MatchPattern is a required field
- MatchPattern *JsonMatchPattern `type:"structure" required:"true"`
- // The parts of the JSON to match against using the MatchPattern. If you specify
- // All, WAF matches against keys and values.
- //
- // MatchScope is a required field
- MatchScope *string `type:"string" required:"true" enum:"JsonMatchScope"`
- // What WAF should do if the body is larger than WAF can inspect. WAF does not
- // support inspecting the entire contents of the body of a web request when
- // the body exceeds 8 KB (8192 bytes). Only the first 8 KB of the request body
- // are forwarded to WAF by the underlying host service.
- //
- // The options for oversize handling are the following:
- //
- // * CONTINUE - Inspect the body normally, according to the rule inspection
- // criteria.
- //
- // * MATCH - Treat the web request as matching the rule statement. WAF applies
- // the rule action to the request.
- //
- // * NO_MATCH - Treat the web request as not matching the rule statement.
- //
- // You can combine the MATCH or NO_MATCH settings for oversize handling with
- // your rule and web ACL action settings, so that you block any request whose
- // body is over 8 KB.
- //
- // Default: CONTINUE
- OversizeHandling *string `type:"string" enum:"OversizeHandling"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s JsonBody) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s JsonBody) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *JsonBody) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "JsonBody"}
- if s.MatchPattern == nil {
- invalidParams.Add(request.NewErrParamRequired("MatchPattern"))
- }
- if s.MatchScope == nil {
- invalidParams.Add(request.NewErrParamRequired("MatchScope"))
- }
- if s.MatchPattern != nil {
- if err := s.MatchPattern.Validate(); err != nil {
- invalidParams.AddNested("MatchPattern", err.(request.ErrInvalidParams))
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetInvalidFallbackBehavior sets the InvalidFallbackBehavior field's value.
- func (s *JsonBody) SetInvalidFallbackBehavior(v string) *JsonBody {
- s.InvalidFallbackBehavior = &v
- return s
- }
- // SetMatchPattern sets the MatchPattern field's value.
- func (s *JsonBody) SetMatchPattern(v *JsonMatchPattern) *JsonBody {
- s.MatchPattern = v
- return s
- }
- // SetMatchScope sets the MatchScope field's value.
- func (s *JsonBody) SetMatchScope(v string) *JsonBody {
- s.MatchScope = &v
- return s
- }
- // SetOversizeHandling sets the OversizeHandling field's value.
- func (s *JsonBody) SetOversizeHandling(v string) *JsonBody {
- s.OversizeHandling = &v
- return s
- }
- // The patterns to look for in the JSON body. WAF inspects the results of these
- // pattern matches against the rule inspection criteria. This is used with the
- // FieldToMatch option JsonBody.
- type JsonMatchPattern struct {
- _ struct{} `type:"structure"`
- // Match all of the elements. See also MatchScope in JsonBody.
- //
- // You must specify either this setting or the IncludedPaths setting, but not
- // both.
- All *All `type:"structure"`
- // Match only the specified include paths. See also MatchScope in JsonBody.
- //
- // Provide the include paths using JSON Pointer syntax. For example, "IncludedPaths":
- // ["/dogs/0/name", "/dogs/1/name"]. For information about this syntax, see
- // the Internet Engineering Task Force (IETF) documentation JavaScript Object
- // Notation (JSON) Pointer (https://tools.ietf.org/html/rfc6901).
- //
- // You must specify either this setting or the All setting, but not both.
- //
- // Don't use this option to include all paths. Instead, use the All setting.
- IncludedPaths []*string `min:"1" type:"list"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s JsonMatchPattern) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s JsonMatchPattern) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *JsonMatchPattern) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "JsonMatchPattern"}
- if s.IncludedPaths != nil && len(s.IncludedPaths) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("IncludedPaths", 1))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetAll sets the All field's value.
- func (s *JsonMatchPattern) SetAll(v *All) *JsonMatchPattern {
- s.All = v
- return s
- }
- // SetIncludedPaths sets the IncludedPaths field's value.
- func (s *JsonMatchPattern) SetIncludedPaths(v []*string) *JsonMatchPattern {
- s.IncludedPaths = v
- return s
- }
- // A single label container. This is used as an element of a label array in
- // multiple contexts, for example, in RuleLabels inside a Rule and in Labels
- // inside a SampledHTTPRequest.
- type Label struct {
- _ struct{} `type:"structure"`
- // The label string.
- //
- // Name is a required field
- Name *string `min:"1" type:"string" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s Label) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s Label) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *Label) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "Label"}
- if s.Name == nil {
- invalidParams.Add(request.NewErrParamRequired("Name"))
- }
- if s.Name != nil && len(*s.Name) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Name", 1))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetName sets the Name field's value.
- func (s *Label) SetName(v string) *Label {
- s.Name = &v
- return s
- }
- // A rule statement to match against labels that have been added to the web
- // request by rules that have already run in the web ACL.
- //
- // The label match statement provides the label or namespace string to search
- // for. The label string can represent a part or all of the fully qualified
- // label name that had been added to the web request. Fully qualified labels
- // have a prefix, optional namespaces, and label name. The prefix identifies
- // the rule group or web ACL context of the rule that added the label. If you
- // do not provide the fully qualified name in your label match string, WAF performs
- // the search for labels that were added in the same context as the label match
- // statement.
- type LabelMatchStatement struct {
- _ struct{} `type:"structure"`
- // The string to match against. The setting you provide for this depends on
- // the match statement's Scope setting:
- //
- // * If the Scope indicates LABEL, then this specification must include the
- // name and can include any number of preceding namespace specifications
- // and prefix up to providing the fully qualified label name.
- //
- // * If the Scope indicates NAMESPACE, then this specification can include
- // any number of contiguous namespace strings, and can include the entire
- // label namespace prefix from the rule group or web ACL where the label
- // originates.
- //
- // Labels are case sensitive and components of a label must be separated by
- // colon, for example NS1:NS2:name.
- //
- // Key is a required field
- Key *string `min:"1" type:"string" required:"true"`
- // Specify whether you want to match using the label name or just the namespace.
- //
- // Scope is a required field
- Scope *string `type:"string" required:"true" enum:"LabelMatchScope"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s LabelMatchStatement) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s LabelMatchStatement) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *LabelMatchStatement) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "LabelMatchStatement"}
- if s.Key == nil {
- invalidParams.Add(request.NewErrParamRequired("Key"))
- }
- if s.Key != nil && len(*s.Key) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Key", 1))
- }
- if s.Scope == nil {
- invalidParams.Add(request.NewErrParamRequired("Scope"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetKey sets the Key field's value.
- func (s *LabelMatchStatement) SetKey(v string) *LabelMatchStatement {
- s.Key = &v
- return s
- }
- // SetScope sets the Scope field's value.
- func (s *LabelMatchStatement) SetScope(v string) *LabelMatchStatement {
- s.Scope = &v
- return s
- }
- // A single label name condition for a Condition in a logging filter.
- type LabelNameCondition struct {
- _ struct{} `type:"structure"`
- // The label name that a log record must contain in order to meet the condition.
- // This must be a fully qualified label name. Fully qualified labels have a
- // prefix, optional namespaces, and label name. The prefix identifies the rule
- // group or web ACL context of the rule that added the label.
- //
- // LabelName is a required field
- LabelName *string `min:"1" type:"string" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s LabelNameCondition) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s LabelNameCondition) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *LabelNameCondition) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "LabelNameCondition"}
- if s.LabelName == nil {
- invalidParams.Add(request.NewErrParamRequired("LabelName"))
- }
- if s.LabelName != nil && len(*s.LabelName) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("LabelName", 1))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetLabelName sets the LabelName field's value.
- func (s *LabelNameCondition) SetLabelName(v string) *LabelNameCondition {
- s.LabelName = &v
- return s
- }
- // List of labels used by one or more of the rules of a RuleGroup. This summary
- // object is used for the following rule group lists:
- //
- // - AvailableLabels - Labels that rules add to matching requests. These
- // labels are defined in the RuleLabels for a Rule.
- //
- // - ConsumedLabels - Labels that rules match against. These labels are defined
- // in a LabelMatchStatement specification, in the Statement definition of
- // a rule.
- type LabelSummary struct {
- _ struct{} `type:"structure"`
- // An individual label specification.
- Name *string `min:"1" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s LabelSummary) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s LabelSummary) GoString() string {
- return s.String()
- }
- // SetName sets the Name field's value.
- func (s *LabelSummary) SetName(v string) *LabelSummary {
- s.Name = &v
- return s
- }
- type ListAvailableManagedRuleGroupVersionsInput struct {
- _ struct{} `type:"structure"`
- // The maximum number of objects that you want WAF to return for this request.
- // If more objects are available, in the response, WAF provides a NextMarker
- // value that you can use in a subsequent call to get the next batch of objects.
- Limit *int64 `min:"1" type:"integer"`
- // The name of the managed rule group. You use this, along with the vendor name,
- // to identify the rule group.
- //
- // Name is a required field
- Name *string `min:"1" type:"string" required:"true"`
- // When you request a list of objects with a Limit setting, if the number of
- // objects that are still available for retrieval exceeds the limit, WAF returns
- // a NextMarker value in the response. To retrieve the next batch of objects,
- // provide the marker from the prior call in your next request.
- NextMarker *string `min:"1" type:"string"`
- // Specifies whether this is for an Amazon CloudFront distribution or for a
- // regional application. A regional application can be an Application Load Balancer
- // (ALB), an Amazon API Gateway REST API, an AppSync GraphQL API, or an Amazon
- // Cognito user pool.
- //
- // To work with CloudFront, you must also specify the Region US East (N. Virginia)
- // as follows:
- //
- // * CLI - Specify the Region when you use the CloudFront scope: --scope=CLOUDFRONT
- // --region=us-east-1.
- //
- // * API and SDKs - For all calls, use the Region endpoint us-east-1.
- //
- // Scope is a required field
- Scope *string `type:"string" required:"true" enum:"Scope"`
- // The name of the managed rule group vendor. You use this, along with the rule
- // group name, to identify the rule group.
- //
- // VendorName is a required field
- VendorName *string `min:"1" type:"string" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListAvailableManagedRuleGroupVersionsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListAvailableManagedRuleGroupVersionsInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ListAvailableManagedRuleGroupVersionsInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ListAvailableManagedRuleGroupVersionsInput"}
- if s.Limit != nil && *s.Limit < 1 {
- invalidParams.Add(request.NewErrParamMinValue("Limit", 1))
- }
- if s.Name == nil {
- invalidParams.Add(request.NewErrParamRequired("Name"))
- }
- if s.Name != nil && len(*s.Name) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Name", 1))
- }
- if s.NextMarker != nil && len(*s.NextMarker) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("NextMarker", 1))
- }
- if s.Scope == nil {
- invalidParams.Add(request.NewErrParamRequired("Scope"))
- }
- if s.VendorName == nil {
- invalidParams.Add(request.NewErrParamRequired("VendorName"))
- }
- if s.VendorName != nil && len(*s.VendorName) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("VendorName", 1))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetLimit sets the Limit field's value.
- func (s *ListAvailableManagedRuleGroupVersionsInput) SetLimit(v int64) *ListAvailableManagedRuleGroupVersionsInput {
- s.Limit = &v
- return s
- }
- // SetName sets the Name field's value.
- func (s *ListAvailableManagedRuleGroupVersionsInput) SetName(v string) *ListAvailableManagedRuleGroupVersionsInput {
- s.Name = &v
- return s
- }
- // SetNextMarker sets the NextMarker field's value.
- func (s *ListAvailableManagedRuleGroupVersionsInput) SetNextMarker(v string) *ListAvailableManagedRuleGroupVersionsInput {
- s.NextMarker = &v
- return s
- }
- // SetScope sets the Scope field's value.
- func (s *ListAvailableManagedRuleGroupVersionsInput) SetScope(v string) *ListAvailableManagedRuleGroupVersionsInput {
- s.Scope = &v
- return s
- }
- // SetVendorName sets the VendorName field's value.
- func (s *ListAvailableManagedRuleGroupVersionsInput) SetVendorName(v string) *ListAvailableManagedRuleGroupVersionsInput {
- s.VendorName = &v
- return s
- }
- type ListAvailableManagedRuleGroupVersionsOutput struct {
- _ struct{} `type:"structure"`
- // The name of the version that's currently set as the default.
- CurrentDefaultVersion *string `min:"1" type:"string"`
- // When you request a list of objects with a Limit setting, if the number of
- // objects that are still available for retrieval exceeds the limit, WAF returns
- // a NextMarker value in the response. To retrieve the next batch of objects,
- // provide the marker from the prior call in your next request.
- NextMarker *string `min:"1" type:"string"`
- // The versions that are currently available for the specified managed rule
- // group.
- Versions []*ManagedRuleGroupVersion `type:"list"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListAvailableManagedRuleGroupVersionsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListAvailableManagedRuleGroupVersionsOutput) GoString() string {
- return s.String()
- }
- // SetCurrentDefaultVersion sets the CurrentDefaultVersion field's value.
- func (s *ListAvailableManagedRuleGroupVersionsOutput) SetCurrentDefaultVersion(v string) *ListAvailableManagedRuleGroupVersionsOutput {
- s.CurrentDefaultVersion = &v
- return s
- }
- // SetNextMarker sets the NextMarker field's value.
- func (s *ListAvailableManagedRuleGroupVersionsOutput) SetNextMarker(v string) *ListAvailableManagedRuleGroupVersionsOutput {
- s.NextMarker = &v
- return s
- }
- // SetVersions sets the Versions field's value.
- func (s *ListAvailableManagedRuleGroupVersionsOutput) SetVersions(v []*ManagedRuleGroupVersion) *ListAvailableManagedRuleGroupVersionsOutput {
- s.Versions = v
- return s
- }
- type ListAvailableManagedRuleGroupsInput struct {
- _ struct{} `type:"structure"`
- // The maximum number of objects that you want WAF to return for this request.
- // If more objects are available, in the response, WAF provides a NextMarker
- // value that you can use in a subsequent call to get the next batch of objects.
- Limit *int64 `min:"1" type:"integer"`
- // When you request a list of objects with a Limit setting, if the number of
- // objects that are still available for retrieval exceeds the limit, WAF returns
- // a NextMarker value in the response. To retrieve the next batch of objects,
- // provide the marker from the prior call in your next request.
- NextMarker *string `min:"1" type:"string"`
- // Specifies whether this is for an Amazon CloudFront distribution or for a
- // regional application. A regional application can be an Application Load Balancer
- // (ALB), an Amazon API Gateway REST API, an AppSync GraphQL API, or an Amazon
- // Cognito user pool.
- //
- // To work with CloudFront, you must also specify the Region US East (N. Virginia)
- // as follows:
- //
- // * CLI - Specify the Region when you use the CloudFront scope: --scope=CLOUDFRONT
- // --region=us-east-1.
- //
- // * API and SDKs - For all calls, use the Region endpoint us-east-1.
- //
- // Scope is a required field
- Scope *string `type:"string" required:"true" enum:"Scope"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListAvailableManagedRuleGroupsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListAvailableManagedRuleGroupsInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ListAvailableManagedRuleGroupsInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ListAvailableManagedRuleGroupsInput"}
- if s.Limit != nil && *s.Limit < 1 {
- invalidParams.Add(request.NewErrParamMinValue("Limit", 1))
- }
- if s.NextMarker != nil && len(*s.NextMarker) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("NextMarker", 1))
- }
- if s.Scope == nil {
- invalidParams.Add(request.NewErrParamRequired("Scope"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetLimit sets the Limit field's value.
- func (s *ListAvailableManagedRuleGroupsInput) SetLimit(v int64) *ListAvailableManagedRuleGroupsInput {
- s.Limit = &v
- return s
- }
- // SetNextMarker sets the NextMarker field's value.
- func (s *ListAvailableManagedRuleGroupsInput) SetNextMarker(v string) *ListAvailableManagedRuleGroupsInput {
- s.NextMarker = &v
- return s
- }
- // SetScope sets the Scope field's value.
- func (s *ListAvailableManagedRuleGroupsInput) SetScope(v string) *ListAvailableManagedRuleGroupsInput {
- s.Scope = &v
- return s
- }
- type ListAvailableManagedRuleGroupsOutput struct {
- _ struct{} `type:"structure"`
- ManagedRuleGroups []*ManagedRuleGroupSummary `type:"list"`
- // When you request a list of objects with a Limit setting, if the number of
- // objects that are still available for retrieval exceeds the limit, WAF returns
- // a NextMarker value in the response. To retrieve the next batch of objects,
- // provide the marker from the prior call in your next request.
- NextMarker *string `min:"1" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListAvailableManagedRuleGroupsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListAvailableManagedRuleGroupsOutput) GoString() string {
- return s.String()
- }
- // SetManagedRuleGroups sets the ManagedRuleGroups field's value.
- func (s *ListAvailableManagedRuleGroupsOutput) SetManagedRuleGroups(v []*ManagedRuleGroupSummary) *ListAvailableManagedRuleGroupsOutput {
- s.ManagedRuleGroups = v
- return s
- }
- // SetNextMarker sets the NextMarker field's value.
- func (s *ListAvailableManagedRuleGroupsOutput) SetNextMarker(v string) *ListAvailableManagedRuleGroupsOutput {
- s.NextMarker = &v
- return s
- }
- type ListIPSetsInput struct {
- _ struct{} `type:"structure"`
- // The maximum number of objects that you want WAF to return for this request.
- // If more objects are available, in the response, WAF provides a NextMarker
- // value that you can use in a subsequent call to get the next batch of objects.
- Limit *int64 `min:"1" type:"integer"`
- // When you request a list of objects with a Limit setting, if the number of
- // objects that are still available for retrieval exceeds the limit, WAF returns
- // a NextMarker value in the response. To retrieve the next batch of objects,
- // provide the marker from the prior call in your next request.
- NextMarker *string `min:"1" type:"string"`
- // Specifies whether this is for an Amazon CloudFront distribution or for a
- // regional application. A regional application can be an Application Load Balancer
- // (ALB), an Amazon API Gateway REST API, an AppSync GraphQL API, or an Amazon
- // Cognito user pool.
- //
- // To work with CloudFront, you must also specify the Region US East (N. Virginia)
- // as follows:
- //
- // * CLI - Specify the Region when you use the CloudFront scope: --scope=CLOUDFRONT
- // --region=us-east-1.
- //
- // * API and SDKs - For all calls, use the Region endpoint us-east-1.
- //
- // Scope is a required field
- Scope *string `type:"string" required:"true" enum:"Scope"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListIPSetsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListIPSetsInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ListIPSetsInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ListIPSetsInput"}
- if s.Limit != nil && *s.Limit < 1 {
- invalidParams.Add(request.NewErrParamMinValue("Limit", 1))
- }
- if s.NextMarker != nil && len(*s.NextMarker) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("NextMarker", 1))
- }
- if s.Scope == nil {
- invalidParams.Add(request.NewErrParamRequired("Scope"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetLimit sets the Limit field's value.
- func (s *ListIPSetsInput) SetLimit(v int64) *ListIPSetsInput {
- s.Limit = &v
- return s
- }
- // SetNextMarker sets the NextMarker field's value.
- func (s *ListIPSetsInput) SetNextMarker(v string) *ListIPSetsInput {
- s.NextMarker = &v
- return s
- }
- // SetScope sets the Scope field's value.
- func (s *ListIPSetsInput) SetScope(v string) *ListIPSetsInput {
- s.Scope = &v
- return s
- }
- type ListIPSetsOutput struct {
- _ struct{} `type:"structure"`
- // Array of IPSets. This may not be the full list of IPSets that you have defined.
- // See the Limit specification for this request.
- IPSets []*IPSetSummary `type:"list"`
- // When you request a list of objects with a Limit setting, if the number of
- // objects that are still available for retrieval exceeds the limit, WAF returns
- // a NextMarker value in the response. To retrieve the next batch of objects,
- // provide the marker from the prior call in your next request.
- NextMarker *string `min:"1" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListIPSetsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListIPSetsOutput) GoString() string {
- return s.String()
- }
- // SetIPSets sets the IPSets field's value.
- func (s *ListIPSetsOutput) SetIPSets(v []*IPSetSummary) *ListIPSetsOutput {
- s.IPSets = v
- return s
- }
- // SetNextMarker sets the NextMarker field's value.
- func (s *ListIPSetsOutput) SetNextMarker(v string) *ListIPSetsOutput {
- s.NextMarker = &v
- return s
- }
- type ListLoggingConfigurationsInput struct {
- _ struct{} `type:"structure"`
- // The maximum number of objects that you want WAF to return for this request.
- // If more objects are available, in the response, WAF provides a NextMarker
- // value that you can use in a subsequent call to get the next batch of objects.
- Limit *int64 `min:"1" type:"integer"`
- // When you request a list of objects with a Limit setting, if the number of
- // objects that are still available for retrieval exceeds the limit, WAF returns
- // a NextMarker value in the response. To retrieve the next batch of objects,
- // provide the marker from the prior call in your next request.
- NextMarker *string `min:"1" type:"string"`
- // Specifies whether this is for an Amazon CloudFront distribution or for a
- // regional application. A regional application can be an Application Load Balancer
- // (ALB), an Amazon API Gateway REST API, an AppSync GraphQL API, or an Amazon
- // Cognito user pool.
- //
- // To work with CloudFront, you must also specify the Region US East (N. Virginia)
- // as follows:
- //
- // * CLI - Specify the Region when you use the CloudFront scope: --scope=CLOUDFRONT
- // --region=us-east-1.
- //
- // * API and SDKs - For all calls, use the Region endpoint us-east-1.
- //
- // Scope is a required field
- Scope *string `type:"string" required:"true" enum:"Scope"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListLoggingConfigurationsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListLoggingConfigurationsInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ListLoggingConfigurationsInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ListLoggingConfigurationsInput"}
- if s.Limit != nil && *s.Limit < 1 {
- invalidParams.Add(request.NewErrParamMinValue("Limit", 1))
- }
- if s.NextMarker != nil && len(*s.NextMarker) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("NextMarker", 1))
- }
- if s.Scope == nil {
- invalidParams.Add(request.NewErrParamRequired("Scope"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetLimit sets the Limit field's value.
- func (s *ListLoggingConfigurationsInput) SetLimit(v int64) *ListLoggingConfigurationsInput {
- s.Limit = &v
- return s
- }
- // SetNextMarker sets the NextMarker field's value.
- func (s *ListLoggingConfigurationsInput) SetNextMarker(v string) *ListLoggingConfigurationsInput {
- s.NextMarker = &v
- return s
- }
- // SetScope sets the Scope field's value.
- func (s *ListLoggingConfigurationsInput) SetScope(v string) *ListLoggingConfigurationsInput {
- s.Scope = &v
- return s
- }
- type ListLoggingConfigurationsOutput struct {
- _ struct{} `type:"structure"`
- LoggingConfigurations []*LoggingConfiguration `type:"list"`
- // When you request a list of objects with a Limit setting, if the number of
- // objects that are still available for retrieval exceeds the limit, WAF returns
- // a NextMarker value in the response. To retrieve the next batch of objects,
- // provide the marker from the prior call in your next request.
- NextMarker *string `min:"1" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListLoggingConfigurationsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListLoggingConfigurationsOutput) GoString() string {
- return s.String()
- }
- // SetLoggingConfigurations sets the LoggingConfigurations field's value.
- func (s *ListLoggingConfigurationsOutput) SetLoggingConfigurations(v []*LoggingConfiguration) *ListLoggingConfigurationsOutput {
- s.LoggingConfigurations = v
- return s
- }
- // SetNextMarker sets the NextMarker field's value.
- func (s *ListLoggingConfigurationsOutput) SetNextMarker(v string) *ListLoggingConfigurationsOutput {
- s.NextMarker = &v
- return s
- }
- type ListManagedRuleSetsInput struct {
- _ struct{} `type:"structure"`
- // The maximum number of objects that you want WAF to return for this request.
- // If more objects are available, in the response, WAF provides a NextMarker
- // value that you can use in a subsequent call to get the next batch of objects.
- Limit *int64 `min:"1" type:"integer"`
- // When you request a list of objects with a Limit setting, if the number of
- // objects that are still available for retrieval exceeds the limit, WAF returns
- // a NextMarker value in the response. To retrieve the next batch of objects,
- // provide the marker from the prior call in your next request.
- NextMarker *string `min:"1" type:"string"`
- // Specifies whether this is for an Amazon CloudFront distribution or for a
- // regional application. A regional application can be an Application Load Balancer
- // (ALB), an Amazon API Gateway REST API, an AppSync GraphQL API, or an Amazon
- // Cognito user pool.
- //
- // To work with CloudFront, you must also specify the Region US East (N. Virginia)
- // as follows:
- //
- // * CLI - Specify the Region when you use the CloudFront scope: --scope=CLOUDFRONT
- // --region=us-east-1.
- //
- // * API and SDKs - For all calls, use the Region endpoint us-east-1.
- //
- // Scope is a required field
- Scope *string `type:"string" required:"true" enum:"Scope"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListManagedRuleSetsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListManagedRuleSetsInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ListManagedRuleSetsInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ListManagedRuleSetsInput"}
- if s.Limit != nil && *s.Limit < 1 {
- invalidParams.Add(request.NewErrParamMinValue("Limit", 1))
- }
- if s.NextMarker != nil && len(*s.NextMarker) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("NextMarker", 1))
- }
- if s.Scope == nil {
- invalidParams.Add(request.NewErrParamRequired("Scope"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetLimit sets the Limit field's value.
- func (s *ListManagedRuleSetsInput) SetLimit(v int64) *ListManagedRuleSetsInput {
- s.Limit = &v
- return s
- }
- // SetNextMarker sets the NextMarker field's value.
- func (s *ListManagedRuleSetsInput) SetNextMarker(v string) *ListManagedRuleSetsInput {
- s.NextMarker = &v
- return s
- }
- // SetScope sets the Scope field's value.
- func (s *ListManagedRuleSetsInput) SetScope(v string) *ListManagedRuleSetsInput {
- s.Scope = &v
- return s
- }
- type ListManagedRuleSetsOutput struct {
- _ struct{} `type:"structure"`
- // Your managed rule sets.
- ManagedRuleSets []*ManagedRuleSetSummary `type:"list"`
- // When you request a list of objects with a Limit setting, if the number of
- // objects that are still available for retrieval exceeds the limit, WAF returns
- // a NextMarker value in the response. To retrieve the next batch of objects,
- // provide the marker from the prior call in your next request.
- NextMarker *string `min:"1" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListManagedRuleSetsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListManagedRuleSetsOutput) GoString() string {
- return s.String()
- }
- // SetManagedRuleSets sets the ManagedRuleSets field's value.
- func (s *ListManagedRuleSetsOutput) SetManagedRuleSets(v []*ManagedRuleSetSummary) *ListManagedRuleSetsOutput {
- s.ManagedRuleSets = v
- return s
- }
- // SetNextMarker sets the NextMarker field's value.
- func (s *ListManagedRuleSetsOutput) SetNextMarker(v string) *ListManagedRuleSetsOutput {
- s.NextMarker = &v
- return s
- }
- type ListMobileSdkReleasesInput struct {
- _ struct{} `type:"structure"`
- // The maximum number of objects that you want WAF to return for this request.
- // If more objects are available, in the response, WAF provides a NextMarker
- // value that you can use in a subsequent call to get the next batch of objects.
- Limit *int64 `min:"1" type:"integer"`
- // When you request a list of objects with a Limit setting, if the number of
- // objects that are still available for retrieval exceeds the limit, WAF returns
- // a NextMarker value in the response. To retrieve the next batch of objects,
- // provide the marker from the prior call in your next request.
- NextMarker *string `min:"1" type:"string"`
- // The device platform to retrieve the list for.
- //
- // Platform is a required field
- Platform *string `type:"string" required:"true" enum:"Platform"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListMobileSdkReleasesInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListMobileSdkReleasesInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ListMobileSdkReleasesInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ListMobileSdkReleasesInput"}
- if s.Limit != nil && *s.Limit < 1 {
- invalidParams.Add(request.NewErrParamMinValue("Limit", 1))
- }
- if s.NextMarker != nil && len(*s.NextMarker) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("NextMarker", 1))
- }
- if s.Platform == nil {
- invalidParams.Add(request.NewErrParamRequired("Platform"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetLimit sets the Limit field's value.
- func (s *ListMobileSdkReleasesInput) SetLimit(v int64) *ListMobileSdkReleasesInput {
- s.Limit = &v
- return s
- }
- // SetNextMarker sets the NextMarker field's value.
- func (s *ListMobileSdkReleasesInput) SetNextMarker(v string) *ListMobileSdkReleasesInput {
- s.NextMarker = &v
- return s
- }
- // SetPlatform sets the Platform field's value.
- func (s *ListMobileSdkReleasesInput) SetPlatform(v string) *ListMobileSdkReleasesInput {
- s.Platform = &v
- return s
- }
- type ListMobileSdkReleasesOutput struct {
- _ struct{} `type:"structure"`
- // When you request a list of objects with a Limit setting, if the number of
- // objects that are still available for retrieval exceeds the limit, WAF returns
- // a NextMarker value in the response. To retrieve the next batch of objects,
- // provide the marker from the prior call in your next request.
- NextMarker *string `min:"1" type:"string"`
- // High level information for the available SDK releases.
- ReleaseSummaries []*ReleaseSummary `type:"list"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListMobileSdkReleasesOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListMobileSdkReleasesOutput) GoString() string {
- return s.String()
- }
- // SetNextMarker sets the NextMarker field's value.
- func (s *ListMobileSdkReleasesOutput) SetNextMarker(v string) *ListMobileSdkReleasesOutput {
- s.NextMarker = &v
- return s
- }
- // SetReleaseSummaries sets the ReleaseSummaries field's value.
- func (s *ListMobileSdkReleasesOutput) SetReleaseSummaries(v []*ReleaseSummary) *ListMobileSdkReleasesOutput {
- s.ReleaseSummaries = v
- return s
- }
- type ListRegexPatternSetsInput struct {
- _ struct{} `type:"structure"`
- // The maximum number of objects that you want WAF to return for this request.
- // If more objects are available, in the response, WAF provides a NextMarker
- // value that you can use in a subsequent call to get the next batch of objects.
- Limit *int64 `min:"1" type:"integer"`
- // When you request a list of objects with a Limit setting, if the number of
- // objects that are still available for retrieval exceeds the limit, WAF returns
- // a NextMarker value in the response. To retrieve the next batch of objects,
- // provide the marker from the prior call in your next request.
- NextMarker *string `min:"1" type:"string"`
- // Specifies whether this is for an Amazon CloudFront distribution or for a
- // regional application. A regional application can be an Application Load Balancer
- // (ALB), an Amazon API Gateway REST API, an AppSync GraphQL API, or an Amazon
- // Cognito user pool.
- //
- // To work with CloudFront, you must also specify the Region US East (N. Virginia)
- // as follows:
- //
- // * CLI - Specify the Region when you use the CloudFront scope: --scope=CLOUDFRONT
- // --region=us-east-1.
- //
- // * API and SDKs - For all calls, use the Region endpoint us-east-1.
- //
- // Scope is a required field
- Scope *string `type:"string" required:"true" enum:"Scope"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListRegexPatternSetsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListRegexPatternSetsInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ListRegexPatternSetsInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ListRegexPatternSetsInput"}
- if s.Limit != nil && *s.Limit < 1 {
- invalidParams.Add(request.NewErrParamMinValue("Limit", 1))
- }
- if s.NextMarker != nil && len(*s.NextMarker) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("NextMarker", 1))
- }
- if s.Scope == nil {
- invalidParams.Add(request.NewErrParamRequired("Scope"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetLimit sets the Limit field's value.
- func (s *ListRegexPatternSetsInput) SetLimit(v int64) *ListRegexPatternSetsInput {
- s.Limit = &v
- return s
- }
- // SetNextMarker sets the NextMarker field's value.
- func (s *ListRegexPatternSetsInput) SetNextMarker(v string) *ListRegexPatternSetsInput {
- s.NextMarker = &v
- return s
- }
- // SetScope sets the Scope field's value.
- func (s *ListRegexPatternSetsInput) SetScope(v string) *ListRegexPatternSetsInput {
- s.Scope = &v
- return s
- }
- type ListRegexPatternSetsOutput struct {
- _ struct{} `type:"structure"`
- // When you request a list of objects with a Limit setting, if the number of
- // objects that are still available for retrieval exceeds the limit, WAF returns
- // a NextMarker value in the response. To retrieve the next batch of objects,
- // provide the marker from the prior call in your next request.
- NextMarker *string `min:"1" type:"string"`
- RegexPatternSets []*RegexPatternSetSummary `type:"list"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListRegexPatternSetsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListRegexPatternSetsOutput) GoString() string {
- return s.String()
- }
- // SetNextMarker sets the NextMarker field's value.
- func (s *ListRegexPatternSetsOutput) SetNextMarker(v string) *ListRegexPatternSetsOutput {
- s.NextMarker = &v
- return s
- }
- // SetRegexPatternSets sets the RegexPatternSets field's value.
- func (s *ListRegexPatternSetsOutput) SetRegexPatternSets(v []*RegexPatternSetSummary) *ListRegexPatternSetsOutput {
- s.RegexPatternSets = v
- return s
- }
- type ListResourcesForWebACLInput struct {
- _ struct{} `type:"structure"`
- // Used for web ACLs that are scoped for regional applications. A regional application
- // can be an Application Load Balancer (ALB), an Amazon API Gateway REST API,
- // an AppSync GraphQL API, or an Amazon Cognito user pool.
- //
- // If you don't provide a resource type, the call uses the resource type APPLICATION_LOAD_BALANCER.
- //
- // Default: APPLICATION_LOAD_BALANCER
- ResourceType *string `type:"string" enum:"ResourceType"`
- // The Amazon Resource Name (ARN) of the web ACL.
- //
- // WebACLArn is a required field
- WebACLArn *string `min:"20" type:"string" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListResourcesForWebACLInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListResourcesForWebACLInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ListResourcesForWebACLInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ListResourcesForWebACLInput"}
- if s.WebACLArn == nil {
- invalidParams.Add(request.NewErrParamRequired("WebACLArn"))
- }
- if s.WebACLArn != nil && len(*s.WebACLArn) < 20 {
- invalidParams.Add(request.NewErrParamMinLen("WebACLArn", 20))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetResourceType sets the ResourceType field's value.
- func (s *ListResourcesForWebACLInput) SetResourceType(v string) *ListResourcesForWebACLInput {
- s.ResourceType = &v
- return s
- }
- // SetWebACLArn sets the WebACLArn field's value.
- func (s *ListResourcesForWebACLInput) SetWebACLArn(v string) *ListResourcesForWebACLInput {
- s.WebACLArn = &v
- return s
- }
- type ListResourcesForWebACLOutput struct {
- _ struct{} `type:"structure"`
- // The array of Amazon Resource Names (ARNs) of the associated resources.
- ResourceArns []*string `type:"list"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListResourcesForWebACLOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListResourcesForWebACLOutput) GoString() string {
- return s.String()
- }
- // SetResourceArns sets the ResourceArns field's value.
- func (s *ListResourcesForWebACLOutput) SetResourceArns(v []*string) *ListResourcesForWebACLOutput {
- s.ResourceArns = v
- return s
- }
- type ListRuleGroupsInput struct {
- _ struct{} `type:"structure"`
- // The maximum number of objects that you want WAF to return for this request.
- // If more objects are available, in the response, WAF provides a NextMarker
- // value that you can use in a subsequent call to get the next batch of objects.
- Limit *int64 `min:"1" type:"integer"`
- // When you request a list of objects with a Limit setting, if the number of
- // objects that are still available for retrieval exceeds the limit, WAF returns
- // a NextMarker value in the response. To retrieve the next batch of objects,
- // provide the marker from the prior call in your next request.
- NextMarker *string `min:"1" type:"string"`
- // Specifies whether this is for an Amazon CloudFront distribution or for a
- // regional application. A regional application can be an Application Load Balancer
- // (ALB), an Amazon API Gateway REST API, an AppSync GraphQL API, or an Amazon
- // Cognito user pool.
- //
- // To work with CloudFront, you must also specify the Region US East (N. Virginia)
- // as follows:
- //
- // * CLI - Specify the Region when you use the CloudFront scope: --scope=CLOUDFRONT
- // --region=us-east-1.
- //
- // * API and SDKs - For all calls, use the Region endpoint us-east-1.
- //
- // Scope is a required field
- Scope *string `type:"string" required:"true" enum:"Scope"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListRuleGroupsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListRuleGroupsInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ListRuleGroupsInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ListRuleGroupsInput"}
- if s.Limit != nil && *s.Limit < 1 {
- invalidParams.Add(request.NewErrParamMinValue("Limit", 1))
- }
- if s.NextMarker != nil && len(*s.NextMarker) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("NextMarker", 1))
- }
- if s.Scope == nil {
- invalidParams.Add(request.NewErrParamRequired("Scope"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetLimit sets the Limit field's value.
- func (s *ListRuleGroupsInput) SetLimit(v int64) *ListRuleGroupsInput {
- s.Limit = &v
- return s
- }
- // SetNextMarker sets the NextMarker field's value.
- func (s *ListRuleGroupsInput) SetNextMarker(v string) *ListRuleGroupsInput {
- s.NextMarker = &v
- return s
- }
- // SetScope sets the Scope field's value.
- func (s *ListRuleGroupsInput) SetScope(v string) *ListRuleGroupsInput {
- s.Scope = &v
- return s
- }
- type ListRuleGroupsOutput struct {
- _ struct{} `type:"structure"`
- // When you request a list of objects with a Limit setting, if the number of
- // objects that are still available for retrieval exceeds the limit, WAF returns
- // a NextMarker value in the response. To retrieve the next batch of objects,
- // provide the marker from the prior call in your next request.
- NextMarker *string `min:"1" type:"string"`
- RuleGroups []*RuleGroupSummary `type:"list"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListRuleGroupsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListRuleGroupsOutput) GoString() string {
- return s.String()
- }
- // SetNextMarker sets the NextMarker field's value.
- func (s *ListRuleGroupsOutput) SetNextMarker(v string) *ListRuleGroupsOutput {
- s.NextMarker = &v
- return s
- }
- // SetRuleGroups sets the RuleGroups field's value.
- func (s *ListRuleGroupsOutput) SetRuleGroups(v []*RuleGroupSummary) *ListRuleGroupsOutput {
- s.RuleGroups = v
- return s
- }
- type ListTagsForResourceInput struct {
- _ struct{} `type:"structure"`
- // The maximum number of objects that you want WAF to return for this request.
- // If more objects are available, in the response, WAF provides a NextMarker
- // value that you can use in a subsequent call to get the next batch of objects.
- Limit *int64 `min:"1" type:"integer"`
- // When you request a list of objects with a Limit setting, if the number of
- // objects that are still available for retrieval exceeds the limit, WAF returns
- // a NextMarker value in the response. To retrieve the next batch of objects,
- // provide the marker from the prior call in your next request.
- NextMarker *string `min:"1" type:"string"`
- // The Amazon Resource Name (ARN) of the resource.
- //
- // ResourceARN is a required field
- ResourceARN *string `min:"20" type:"string" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListTagsForResourceInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListTagsForResourceInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ListTagsForResourceInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ListTagsForResourceInput"}
- if s.Limit != nil && *s.Limit < 1 {
- invalidParams.Add(request.NewErrParamMinValue("Limit", 1))
- }
- if s.NextMarker != nil && len(*s.NextMarker) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("NextMarker", 1))
- }
- if s.ResourceARN == nil {
- invalidParams.Add(request.NewErrParamRequired("ResourceARN"))
- }
- if s.ResourceARN != nil && len(*s.ResourceARN) < 20 {
- invalidParams.Add(request.NewErrParamMinLen("ResourceARN", 20))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetLimit sets the Limit field's value.
- func (s *ListTagsForResourceInput) SetLimit(v int64) *ListTagsForResourceInput {
- s.Limit = &v
- return s
- }
- // SetNextMarker sets the NextMarker field's value.
- func (s *ListTagsForResourceInput) SetNextMarker(v string) *ListTagsForResourceInput {
- s.NextMarker = &v
- return s
- }
- // SetResourceARN sets the ResourceARN field's value.
- func (s *ListTagsForResourceInput) SetResourceARN(v string) *ListTagsForResourceInput {
- s.ResourceARN = &v
- return s
- }
- type ListTagsForResourceOutput struct {
- _ struct{} `type:"structure"`
- // When you request a list of objects with a Limit setting, if the number of
- // objects that are still available for retrieval exceeds the limit, WAF returns
- // a NextMarker value in the response. To retrieve the next batch of objects,
- // provide the marker from the prior call in your next request.
- NextMarker *string `min:"1" type:"string"`
- // The collection of tagging definitions for the resource.
- TagInfoForResource *TagInfoForResource `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListTagsForResourceOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListTagsForResourceOutput) GoString() string {
- return s.String()
- }
- // SetNextMarker sets the NextMarker field's value.
- func (s *ListTagsForResourceOutput) SetNextMarker(v string) *ListTagsForResourceOutput {
- s.NextMarker = &v
- return s
- }
- // SetTagInfoForResource sets the TagInfoForResource field's value.
- func (s *ListTagsForResourceOutput) SetTagInfoForResource(v *TagInfoForResource) *ListTagsForResourceOutput {
- s.TagInfoForResource = v
- return s
- }
- type ListWebACLsInput struct {
- _ struct{} `type:"structure"`
- // The maximum number of objects that you want WAF to return for this request.
- // If more objects are available, in the response, WAF provides a NextMarker
- // value that you can use in a subsequent call to get the next batch of objects.
- Limit *int64 `min:"1" type:"integer"`
- // When you request a list of objects with a Limit setting, if the number of
- // objects that are still available for retrieval exceeds the limit, WAF returns
- // a NextMarker value in the response. To retrieve the next batch of objects,
- // provide the marker from the prior call in your next request.
- NextMarker *string `min:"1" type:"string"`
- // Specifies whether this is for an Amazon CloudFront distribution or for a
- // regional application. A regional application can be an Application Load Balancer
- // (ALB), an Amazon API Gateway REST API, an AppSync GraphQL API, or an Amazon
- // Cognito user pool.
- //
- // To work with CloudFront, you must also specify the Region US East (N. Virginia)
- // as follows:
- //
- // * CLI - Specify the Region when you use the CloudFront scope: --scope=CLOUDFRONT
- // --region=us-east-1.
- //
- // * API and SDKs - For all calls, use the Region endpoint us-east-1.
- //
- // Scope is a required field
- Scope *string `type:"string" required:"true" enum:"Scope"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListWebACLsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListWebACLsInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ListWebACLsInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ListWebACLsInput"}
- if s.Limit != nil && *s.Limit < 1 {
- invalidParams.Add(request.NewErrParamMinValue("Limit", 1))
- }
- if s.NextMarker != nil && len(*s.NextMarker) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("NextMarker", 1))
- }
- if s.Scope == nil {
- invalidParams.Add(request.NewErrParamRequired("Scope"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetLimit sets the Limit field's value.
- func (s *ListWebACLsInput) SetLimit(v int64) *ListWebACLsInput {
- s.Limit = &v
- return s
- }
- // SetNextMarker sets the NextMarker field's value.
- func (s *ListWebACLsInput) SetNextMarker(v string) *ListWebACLsInput {
- s.NextMarker = &v
- return s
- }
- // SetScope sets the Scope field's value.
- func (s *ListWebACLsInput) SetScope(v string) *ListWebACLsInput {
- s.Scope = &v
- return s
- }
- type ListWebACLsOutput struct {
- _ struct{} `type:"structure"`
- // When you request a list of objects with a Limit setting, if the number of
- // objects that are still available for retrieval exceeds the limit, WAF returns
- // a NextMarker value in the response. To retrieve the next batch of objects,
- // provide the marker from the prior call in your next request.
- NextMarker *string `min:"1" type:"string"`
- WebACLs []*WebACLSummary `type:"list"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListWebACLsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ListWebACLsOutput) GoString() string {
- return s.String()
- }
- // SetNextMarker sets the NextMarker field's value.
- func (s *ListWebACLsOutput) SetNextMarker(v string) *ListWebACLsOutput {
- s.NextMarker = &v
- return s
- }
- // SetWebACLs sets the WebACLs field's value.
- func (s *ListWebACLsOutput) SetWebACLs(v []*WebACLSummary) *ListWebACLsOutput {
- s.WebACLs = v
- return s
- }
- // Defines an association between logging destinations and a web ACL resource,
- // for logging from WAF. As part of the association, you can specify parts of
- // the standard logging fields to keep out of the logs and you can specify filters
- // so that you log only a subset of the logging records.
- //
- // You can define one logging destination per web ACL.
- //
- // You can access information about the traffic that WAF inspects using the
- // following steps:
- //
- // Create your logging destination. You can use an Amazon CloudWatch Logs log
- // group, an Amazon Simple Storage Service (Amazon S3) bucket, or an Amazon
- // Kinesis Data Firehose.
- //
- // The name that you give the destination must start with aws-waf-logs-. Depending
- // on the type of destination, you might need to configure additional settings
- // or permissions.
- //
- // For configuration requirements and pricing information for each destination
- // type, see Logging web ACL traffic (https://docs.aws.amazon.com/waf/latest/developerguide/logging.html)
- // in the WAF Developer Guide.
- //
- // Associate your logging destination to your web ACL using a PutLoggingConfiguration
- // request.
- //
- // When you successfully enable logging using a PutLoggingConfiguration request,
- // WAF creates an additional role or policy that is required to write logs to
- // the logging destination. For an Amazon CloudWatch Logs log group, WAF creates
- // a resource policy on the log group. For an Amazon S3 bucket, WAF creates
- // a bucket policy. For an Amazon Kinesis Data Firehose, WAF creates a service-linked
- // role.
- //
- // For additional information about web ACL logging, see Logging web ACL traffic
- // information (https://docs.aws.amazon.com/waf/latest/developerguide/logging.html)
- // in the WAF Developer Guide.
- type LoggingConfiguration struct {
- _ struct{} `type:"structure"`
- // The logging destination configuration that you want to associate with the
- // web ACL.
- //
- // You can associate one logging destination to a web ACL.
- //
- // LogDestinationConfigs is a required field
- LogDestinationConfigs []*string `min:"1" type:"list" required:"true"`
- // Filtering that specifies which web requests are kept in the logs and which
- // are dropped. You can filter on the rule action and on the web request labels
- // that were applied by matching rules during web ACL evaluation.
- LoggingFilter *LoggingFilter `type:"structure"`
- // Indicates whether the logging configuration was created by Firewall Manager,
- // as part of an WAF policy configuration. If true, only Firewall Manager can
- // modify or delete the configuration.
- ManagedByFirewallManager *bool `type:"boolean"`
- // The parts of the request that you want to keep out of the logs. For example,
- // if you redact the SingleHeader field, the HEADER field in the logs will be
- // xxx.
- //
- // You can specify only the following fields for redaction: UriPath, QueryString,
- // SingleHeader, Method, and JsonBody.
- RedactedFields []*FieldToMatch `type:"list"`
- // The Amazon Resource Name (ARN) of the web ACL that you want to associate
- // with LogDestinationConfigs.
- //
- // ResourceArn is a required field
- ResourceArn *string `min:"20" type:"string" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s LoggingConfiguration) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s LoggingConfiguration) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *LoggingConfiguration) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "LoggingConfiguration"}
- if s.LogDestinationConfigs == nil {
- invalidParams.Add(request.NewErrParamRequired("LogDestinationConfigs"))
- }
- if s.LogDestinationConfigs != nil && len(s.LogDestinationConfigs) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("LogDestinationConfigs", 1))
- }
- if s.ResourceArn == nil {
- invalidParams.Add(request.NewErrParamRequired("ResourceArn"))
- }
- if s.ResourceArn != nil && len(*s.ResourceArn) < 20 {
- invalidParams.Add(request.NewErrParamMinLen("ResourceArn", 20))
- }
- if s.LoggingFilter != nil {
- if err := s.LoggingFilter.Validate(); err != nil {
- invalidParams.AddNested("LoggingFilter", err.(request.ErrInvalidParams))
- }
- }
- if s.RedactedFields != nil {
- for i, v := range s.RedactedFields {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "RedactedFields", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetLogDestinationConfigs sets the LogDestinationConfigs field's value.
- func (s *LoggingConfiguration) SetLogDestinationConfigs(v []*string) *LoggingConfiguration {
- s.LogDestinationConfigs = v
- return s
- }
- // SetLoggingFilter sets the LoggingFilter field's value.
- func (s *LoggingConfiguration) SetLoggingFilter(v *LoggingFilter) *LoggingConfiguration {
- s.LoggingFilter = v
- return s
- }
- // SetManagedByFirewallManager sets the ManagedByFirewallManager field's value.
- func (s *LoggingConfiguration) SetManagedByFirewallManager(v bool) *LoggingConfiguration {
- s.ManagedByFirewallManager = &v
- return s
- }
- // SetRedactedFields sets the RedactedFields field's value.
- func (s *LoggingConfiguration) SetRedactedFields(v []*FieldToMatch) *LoggingConfiguration {
- s.RedactedFields = v
- return s
- }
- // SetResourceArn sets the ResourceArn field's value.
- func (s *LoggingConfiguration) SetResourceArn(v string) *LoggingConfiguration {
- s.ResourceArn = &v
- return s
- }
- // Filtering that specifies which web requests are kept in the logs and which
- // are dropped, defined for a web ACL's LoggingConfiguration.
- //
- // You can filter on the rule action and on the web request labels that were
- // applied by matching rules during web ACL evaluation.
- type LoggingFilter struct {
- _ struct{} `type:"structure"`
- // Default handling for logs that don't match any of the specified filtering
- // conditions.
- //
- // DefaultBehavior is a required field
- DefaultBehavior *string `type:"string" required:"true" enum:"FilterBehavior"`
- // The filters that you want to apply to the logs.
- //
- // Filters is a required field
- Filters []*Filter `min:"1" type:"list" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s LoggingFilter) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s LoggingFilter) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *LoggingFilter) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "LoggingFilter"}
- if s.DefaultBehavior == nil {
- invalidParams.Add(request.NewErrParamRequired("DefaultBehavior"))
- }
- if s.Filters == nil {
- invalidParams.Add(request.NewErrParamRequired("Filters"))
- }
- if s.Filters != nil && len(s.Filters) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Filters", 1))
- }
- if s.Filters != nil {
- for i, v := range s.Filters {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "Filters", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetDefaultBehavior sets the DefaultBehavior field's value.
- func (s *LoggingFilter) SetDefaultBehavior(v string) *LoggingFilter {
- s.DefaultBehavior = &v
- return s
- }
- // SetFilters sets the Filters field's value.
- func (s *LoggingFilter) SetFilters(v []*Filter) *LoggingFilter {
- s.Filters = v
- return s
- }
- // Additional information that's used by a managed rule group. Many managed
- // rule groups don't require this.
- //
- // Use the AWSManagedRulesBotControlRuleSet configuration object to configure
- // the protection level that you want the Bot Control rule group to use.
- //
- // For example specifications, see the examples section of CreateWebACL.
- type ManagedRuleGroupConfig struct {
- _ struct{} `type:"structure"`
- // Additional configuration for using the Bot Control managed rule group. Use
- // this to specify the inspection level that you want to use. For information
- // about using the Bot Control managed rule group, see WAF Bot Control rule
- // group (https://docs.aws.amazon.com/waf/latest/developerguide/aws-managed-rule-groups-bot.html)
- // and WAF Bot Control (https://docs.aws.amazon.com/waf/latest/developerguide/waf-bot-control.html)
- // in the WAF Developer Guide.
- AWSManagedRulesBotControlRuleSet *AWSManagedRulesBotControlRuleSet `type:"structure"`
- // The path of the login endpoint for your application. For example, for the
- // URL https://example.com/web/login, you would provide the path /web/login.
- LoginPath *string `min:"1" type:"string"`
- // Details about your login page password field.
- PasswordField *PasswordField `type:"structure"`
- // The payload type for your login endpoint, either JSON or form encoded.
- PayloadType *string `type:"string" enum:"PayloadType"`
- // Details about your login page username field.
- UsernameField *UsernameField `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ManagedRuleGroupConfig) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ManagedRuleGroupConfig) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ManagedRuleGroupConfig) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ManagedRuleGroupConfig"}
- if s.LoginPath != nil && len(*s.LoginPath) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("LoginPath", 1))
- }
- if s.AWSManagedRulesBotControlRuleSet != nil {
- if err := s.AWSManagedRulesBotControlRuleSet.Validate(); err != nil {
- invalidParams.AddNested("AWSManagedRulesBotControlRuleSet", err.(request.ErrInvalidParams))
- }
- }
- if s.PasswordField != nil {
- if err := s.PasswordField.Validate(); err != nil {
- invalidParams.AddNested("PasswordField", err.(request.ErrInvalidParams))
- }
- }
- if s.UsernameField != nil {
- if err := s.UsernameField.Validate(); err != nil {
- invalidParams.AddNested("UsernameField", err.(request.ErrInvalidParams))
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetAWSManagedRulesBotControlRuleSet sets the AWSManagedRulesBotControlRuleSet field's value.
- func (s *ManagedRuleGroupConfig) SetAWSManagedRulesBotControlRuleSet(v *AWSManagedRulesBotControlRuleSet) *ManagedRuleGroupConfig {
- s.AWSManagedRulesBotControlRuleSet = v
- return s
- }
- // SetLoginPath sets the LoginPath field's value.
- func (s *ManagedRuleGroupConfig) SetLoginPath(v string) *ManagedRuleGroupConfig {
- s.LoginPath = &v
- return s
- }
- // SetPasswordField sets the PasswordField field's value.
- func (s *ManagedRuleGroupConfig) SetPasswordField(v *PasswordField) *ManagedRuleGroupConfig {
- s.PasswordField = v
- return s
- }
- // SetPayloadType sets the PayloadType field's value.
- func (s *ManagedRuleGroupConfig) SetPayloadType(v string) *ManagedRuleGroupConfig {
- s.PayloadType = &v
- return s
- }
- // SetUsernameField sets the UsernameField field's value.
- func (s *ManagedRuleGroupConfig) SetUsernameField(v *UsernameField) *ManagedRuleGroupConfig {
- s.UsernameField = v
- return s
- }
- // A rule statement used to run the rules that are defined in a managed rule
- // group. To use this, provide the vendor name and the name of the rule group
- // in this statement. You can retrieve the required names by calling ListAvailableManagedRuleGroups.
- //
- // You cannot nest a ManagedRuleGroupStatement, for example for use inside a
- // NotStatement or OrStatement. It can only be referenced as a top-level statement
- // within a rule.
- //
- // You are charged additional fees when you use the WAF Bot Control managed
- // rule group AWSManagedRulesBotControlRuleSet or the WAF Fraud Control account
- // takeover prevention (ATP) managed rule group AWSManagedRulesATPRuleSet. For
- // more information, see WAF Pricing (http://aws.amazon.com/waf/pricing/).
- type ManagedRuleGroupStatement struct {
- _ struct{} `type:"structure"`
- // Rules in the referenced rule group whose actions are set to Count.
- //
- // Instead of this option, use RuleActionOverrides. It accepts any valid action
- // setting, including Count.
- ExcludedRules []*ExcludedRule `type:"list"`
- // Additional information that's used by a managed rule group. Many managed
- // rule groups don't require this.
- //
- // Use the AWSManagedRulesBotControlRuleSet configuration object to configure
- // the protection level that you want the Bot Control rule group to use.
- ManagedRuleGroupConfigs []*ManagedRuleGroupConfig `min:"1" type:"list"`
- // The name of the managed rule group. You use this, along with the vendor name,
- // to identify the rule group.
- //
- // Name is a required field
- Name *string `min:"1" type:"string" required:"true"`
- // Action settings to use in the place of the rule actions that are configured
- // inside the rule group. You specify one override for each rule whose action
- // you want to change.
- //
- // You can use overrides for testing, for example you can override all of rule
- // actions to Count and then monitor the resulting count metrics to understand
- // how the rule group would handle your web traffic. You can also permanently
- // override some or all actions, to modify how the rule group manages your web
- // traffic.
- RuleActionOverrides []*RuleActionOverride `min:"1" type:"list"`
- // An optional nested statement that narrows the scope of the web requests that
- // are evaluated by the managed rule group. Requests are only evaluated by the
- // rule group if they match the scope-down statement. You can use any nestable
- // Statement in the scope-down statement, and you can nest statements at any
- // level, the same as you can for a rule statement.
- ScopeDownStatement *Statement `type:"structure"`
- // The name of the managed rule group vendor. You use this, along with the rule
- // group name, to identify the rule group.
- //
- // VendorName is a required field
- VendorName *string `min:"1" type:"string" required:"true"`
- // The version of the managed rule group to use. If you specify this, the version
- // setting is fixed until you change it. If you don't specify this, WAF uses
- // the vendor's default version, and then keeps the version at the vendor's
- // default when the vendor updates the managed rule group settings.
- Version *string `min:"1" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ManagedRuleGroupStatement) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ManagedRuleGroupStatement) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *ManagedRuleGroupStatement) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "ManagedRuleGroupStatement"}
- if s.ManagedRuleGroupConfigs != nil && len(s.ManagedRuleGroupConfigs) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("ManagedRuleGroupConfigs", 1))
- }
- if s.Name == nil {
- invalidParams.Add(request.NewErrParamRequired("Name"))
- }
- if s.Name != nil && len(*s.Name) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Name", 1))
- }
- if s.RuleActionOverrides != nil && len(s.RuleActionOverrides) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("RuleActionOverrides", 1))
- }
- if s.VendorName == nil {
- invalidParams.Add(request.NewErrParamRequired("VendorName"))
- }
- if s.VendorName != nil && len(*s.VendorName) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("VendorName", 1))
- }
- if s.Version != nil && len(*s.Version) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Version", 1))
- }
- if s.ExcludedRules != nil {
- for i, v := range s.ExcludedRules {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "ExcludedRules", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if s.ManagedRuleGroupConfigs != nil {
- for i, v := range s.ManagedRuleGroupConfigs {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "ManagedRuleGroupConfigs", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if s.RuleActionOverrides != nil {
- for i, v := range s.RuleActionOverrides {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "RuleActionOverrides", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if s.ScopeDownStatement != nil {
- if err := s.ScopeDownStatement.Validate(); err != nil {
- invalidParams.AddNested("ScopeDownStatement", err.(request.ErrInvalidParams))
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetExcludedRules sets the ExcludedRules field's value.
- func (s *ManagedRuleGroupStatement) SetExcludedRules(v []*ExcludedRule) *ManagedRuleGroupStatement {
- s.ExcludedRules = v
- return s
- }
- // SetManagedRuleGroupConfigs sets the ManagedRuleGroupConfigs field's value.
- func (s *ManagedRuleGroupStatement) SetManagedRuleGroupConfigs(v []*ManagedRuleGroupConfig) *ManagedRuleGroupStatement {
- s.ManagedRuleGroupConfigs = v
- return s
- }
- // SetName sets the Name field's value.
- func (s *ManagedRuleGroupStatement) SetName(v string) *ManagedRuleGroupStatement {
- s.Name = &v
- return s
- }
- // SetRuleActionOverrides sets the RuleActionOverrides field's value.
- func (s *ManagedRuleGroupStatement) SetRuleActionOverrides(v []*RuleActionOverride) *ManagedRuleGroupStatement {
- s.RuleActionOverrides = v
- return s
- }
- // SetScopeDownStatement sets the ScopeDownStatement field's value.
- func (s *ManagedRuleGroupStatement) SetScopeDownStatement(v *Statement) *ManagedRuleGroupStatement {
- s.ScopeDownStatement = v
- return s
- }
- // SetVendorName sets the VendorName field's value.
- func (s *ManagedRuleGroupStatement) SetVendorName(v string) *ManagedRuleGroupStatement {
- s.VendorName = &v
- return s
- }
- // SetVersion sets the Version field's value.
- func (s *ManagedRuleGroupStatement) SetVersion(v string) *ManagedRuleGroupStatement {
- s.Version = &v
- return s
- }
- // High-level information about a managed rule group, returned by ListAvailableManagedRuleGroups.
- // This provides information like the name and vendor name, that you provide
- // when you add a ManagedRuleGroupStatement to a web ACL. Managed rule groups
- // include Amazon Web Services Managed Rules rule groups, which are free of
- // charge to WAF customers, and Amazon Web Services Marketplace managed rule
- // groups, which you can subscribe to through Amazon Web Services Marketplace.
- type ManagedRuleGroupSummary struct {
- _ struct{} `type:"structure"`
- // The description of the managed rule group, provided by Amazon Web Services
- // Managed Rules or the Amazon Web Services Marketplace seller who manages it.
- Description *string `min:"1" type:"string"`
- // The name of the managed rule group. You use this, along with the vendor name,
- // to identify the rule group.
- Name *string `min:"1" type:"string"`
- // The name of the managed rule group vendor. You use this, along with the rule
- // group name, to identify the rule group.
- VendorName *string `min:"1" type:"string"`
- // Indicates whether the managed rule group is versioned. If it is, you can
- // retrieve the versions list by calling ListAvailableManagedRuleGroupVersions.
- VersioningSupported *bool `type:"boolean"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ManagedRuleGroupSummary) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ManagedRuleGroupSummary) GoString() string {
- return s.String()
- }
- // SetDescription sets the Description field's value.
- func (s *ManagedRuleGroupSummary) SetDescription(v string) *ManagedRuleGroupSummary {
- s.Description = &v
- return s
- }
- // SetName sets the Name field's value.
- func (s *ManagedRuleGroupSummary) SetName(v string) *ManagedRuleGroupSummary {
- s.Name = &v
- return s
- }
- // SetVendorName sets the VendorName field's value.
- func (s *ManagedRuleGroupSummary) SetVendorName(v string) *ManagedRuleGroupSummary {
- s.VendorName = &v
- return s
- }
- // SetVersioningSupported sets the VersioningSupported field's value.
- func (s *ManagedRuleGroupSummary) SetVersioningSupported(v bool) *ManagedRuleGroupSummary {
- s.VersioningSupported = &v
- return s
- }
- // Describes a single version of a managed rule group.
- type ManagedRuleGroupVersion struct {
- _ struct{} `type:"structure"`
- // The date and time that the managed rule group owner updated the rule group
- // version information.
- LastUpdateTimestamp *time.Time `type:"timestamp"`
- // The version name.
- Name *string `min:"1" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ManagedRuleGroupVersion) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ManagedRuleGroupVersion) GoString() string {
- return s.String()
- }
- // SetLastUpdateTimestamp sets the LastUpdateTimestamp field's value.
- func (s *ManagedRuleGroupVersion) SetLastUpdateTimestamp(v time.Time) *ManagedRuleGroupVersion {
- s.LastUpdateTimestamp = &v
- return s
- }
- // SetName sets the Name field's value.
- func (s *ManagedRuleGroupVersion) SetName(v string) *ManagedRuleGroupVersion {
- s.Name = &v
- return s
- }
- // A set of rules that is managed by Amazon Web Services and Amazon Web Services
- // Marketplace sellers to provide versioned managed rule groups for customers
- // of WAF.
- //
- // This is intended for use only by vendors of managed rule sets. Vendors are
- // Amazon Web Services and Amazon Web Services Marketplace sellers.
- //
- // Vendors, you can use the managed rule set APIs to provide controlled rollout
- // of your versioned managed rule group offerings for your customers. The APIs
- // are ListManagedRuleSets, GetManagedRuleSet, PutManagedRuleSetVersions, and
- // UpdateManagedRuleSetVersionExpiryDate.
- type ManagedRuleSet struct {
- _ struct{} `type:"structure"`
- // The Amazon Resource Name (ARN) of the entity.
- //
- // ARN is a required field
- ARN *string `min:"20" type:"string" required:"true"`
- // A description of the set that helps with identification.
- Description *string `min:"1" type:"string"`
- // A unique identifier for the managed rule set. The ID is returned in the responses
- // to commands like list. You provide it to operations like get and update.
- //
- // Id is a required field
- Id *string `min:"1" type:"string" required:"true"`
- // The label namespace prefix for the managed rule groups that are offered to
- // customers from this managed rule set. All labels that are added by rules
- // in the managed rule group have this prefix.
- //
- // * The syntax for the label namespace prefix for a managed rule group is
- // the following: awswaf:managed:<vendor>:<rule group name>:
- //
- // * When a rule with a label matches a web request, WAF adds the fully qualified
- // label to the request. A fully qualified label is made up of the label
- // namespace from the rule group or web ACL where the rule is defined and
- // the label from the rule, separated by a colon: <label namespace>:<label
- // from rule>
- LabelNamespace *string `min:"1" type:"string"`
- // The name of the managed rule set. You use this, along with the rule set ID,
- // to identify the rule set.
- //
- // This name is assigned to the corresponding managed rule group, which your
- // customers can access and use.
- //
- // Name is a required field
- Name *string `min:"1" type:"string" required:"true"`
- // The versions of this managed rule set that are available for use by customers.
- PublishedVersions map[string]*ManagedRuleSetVersion `type:"map"`
- // The version that you would like your customers to use.
- RecommendedVersion *string `min:"1" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ManagedRuleSet) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ManagedRuleSet) GoString() string {
- return s.String()
- }
- // SetARN sets the ARN field's value.
- func (s *ManagedRuleSet) SetARN(v string) *ManagedRuleSet {
- s.ARN = &v
- return s
- }
- // SetDescription sets the Description field's value.
- func (s *ManagedRuleSet) SetDescription(v string) *ManagedRuleSet {
- s.Description = &v
- return s
- }
- // SetId sets the Id field's value.
- func (s *ManagedRuleSet) SetId(v string) *ManagedRuleSet {
- s.Id = &v
- return s
- }
- // SetLabelNamespace sets the LabelNamespace field's value.
- func (s *ManagedRuleSet) SetLabelNamespace(v string) *ManagedRuleSet {
- s.LabelNamespace = &v
- return s
- }
- // SetName sets the Name field's value.
- func (s *ManagedRuleSet) SetName(v string) *ManagedRuleSet {
- s.Name = &v
- return s
- }
- // SetPublishedVersions sets the PublishedVersions field's value.
- func (s *ManagedRuleSet) SetPublishedVersions(v map[string]*ManagedRuleSetVersion) *ManagedRuleSet {
- s.PublishedVersions = v
- return s
- }
- // SetRecommendedVersion sets the RecommendedVersion field's value.
- func (s *ManagedRuleSet) SetRecommendedVersion(v string) *ManagedRuleSet {
- s.RecommendedVersion = &v
- return s
- }
- // High-level information for a managed rule set.
- //
- // This is intended for use only by vendors of managed rule sets. Vendors are
- // Amazon Web Services and Amazon Web Services Marketplace sellers.
- //
- // Vendors, you can use the managed rule set APIs to provide controlled rollout
- // of your versioned managed rule group offerings for your customers. The APIs
- // are ListManagedRuleSets, GetManagedRuleSet, PutManagedRuleSetVersions, and
- // UpdateManagedRuleSetVersionExpiryDate.
- type ManagedRuleSetSummary struct {
- _ struct{} `type:"structure"`
- // The Amazon Resource Name (ARN) of the entity.
- ARN *string `min:"20" type:"string"`
- // A description of the set that helps with identification.
- Description *string `min:"1" type:"string"`
- // A unique identifier for the managed rule set. The ID is returned in the responses
- // to commands like list. You provide it to operations like get and update.
- Id *string `min:"1" type:"string"`
- // The label namespace prefix for the managed rule groups that are offered to
- // customers from this managed rule set. All labels that are added by rules
- // in the managed rule group have this prefix.
- //
- // * The syntax for the label namespace prefix for a managed rule group is
- // the following: awswaf:managed:<vendor>:<rule group name>:
- //
- // * When a rule with a label matches a web request, WAF adds the fully qualified
- // label to the request. A fully qualified label is made up of the label
- // namespace from the rule group or web ACL where the rule is defined and
- // the label from the rule, separated by a colon: <label namespace>:<label
- // from rule>
- LabelNamespace *string `min:"1" type:"string"`
- // A token used for optimistic locking. WAF returns a token to your get and
- // list requests, to mark the state of the entity at the time of the request.
- // To make changes to the entity associated with the token, you provide the
- // token to operations like update and delete. WAF uses the token to ensure
- // that no changes have been made to the entity since you last retrieved it.
- // If a change has been made, the update fails with a WAFOptimisticLockException.
- // If this happens, perform another get, and use the new token returned by that
- // operation.
- LockToken *string `min:"1" type:"string"`
- // The name of the managed rule set. You use this, along with the rule set ID,
- // to identify the rule set.
- //
- // This name is assigned to the corresponding managed rule group, which your
- // customers can access and use.
- Name *string `min:"1" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ManagedRuleSetSummary) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ManagedRuleSetSummary) GoString() string {
- return s.String()
- }
- // SetARN sets the ARN field's value.
- func (s *ManagedRuleSetSummary) SetARN(v string) *ManagedRuleSetSummary {
- s.ARN = &v
- return s
- }
- // SetDescription sets the Description field's value.
- func (s *ManagedRuleSetSummary) SetDescription(v string) *ManagedRuleSetSummary {
- s.Description = &v
- return s
- }
- // SetId sets the Id field's value.
- func (s *ManagedRuleSetSummary) SetId(v string) *ManagedRuleSetSummary {
- s.Id = &v
- return s
- }
- // SetLabelNamespace sets the LabelNamespace field's value.
- func (s *ManagedRuleSetSummary) SetLabelNamespace(v string) *ManagedRuleSetSummary {
- s.LabelNamespace = &v
- return s
- }
- // SetLockToken sets the LockToken field's value.
- func (s *ManagedRuleSetSummary) SetLockToken(v string) *ManagedRuleSetSummary {
- s.LockToken = &v
- return s
- }
- // SetName sets the Name field's value.
- func (s *ManagedRuleSetSummary) SetName(v string) *ManagedRuleSetSummary {
- s.Name = &v
- return s
- }
- // Information for a single version of a managed rule set.
- //
- // This is intended for use only by vendors of managed rule sets. Vendors are
- // Amazon Web Services and Amazon Web Services Marketplace sellers.
- //
- // Vendors, you can use the managed rule set APIs to provide controlled rollout
- // of your versioned managed rule group offerings for your customers. The APIs
- // are ListManagedRuleSets, GetManagedRuleSet, PutManagedRuleSetVersions, and
- // UpdateManagedRuleSetVersionExpiryDate.
- type ManagedRuleSetVersion struct {
- _ struct{} `type:"structure"`
- // The Amazon Resource Name (ARN) of the vendor rule group that's used to define
- // the published version of your managed rule group.
- AssociatedRuleGroupArn *string `min:"20" type:"string"`
- // The web ACL capacity units (WCUs) required for this rule group.
- //
- // WAF uses WCUs to calculate and control the operating resources that are used
- // to run your rules, rule groups, and web ACLs. WAF calculates capacity differently
- // for each rule type, to reflect the relative cost of each rule. Simple rules
- // that cost little to run use fewer WCUs than more complex rules that use more
- // processing power. Rule group capacity is fixed at creation, which helps users
- // plan their web ACL WCU usage when they use a rule group. The WCU limit for
- // web ACLs is 1,500.
- Capacity *int64 `min:"1" type:"long"`
- // The time that this version is set to expire.
- //
- // Times are in Coordinated Universal Time (UTC) format. UTC format includes
- // the special designator, Z. For example, "2016-09-27T14:50Z".
- ExpiryTimestamp *time.Time `type:"timestamp"`
- // The amount of time you expect this version of your managed rule group to
- // last, in days.
- ForecastedLifetime *int64 `min:"1" type:"integer"`
- // The last time that you updated this version.
- //
- // Times are in Coordinated Universal Time (UTC) format. UTC format includes
- // the special designator, Z. For example, "2016-09-27T14:50Z".
- LastUpdateTimestamp *time.Time `type:"timestamp"`
- // The time that you first published this version.
- //
- // Times are in Coordinated Universal Time (UTC) format. UTC format includes
- // the special designator, Z. For example, "2016-09-27T14:50Z".
- PublishTimestamp *time.Time `type:"timestamp"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ManagedRuleSetVersion) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ManagedRuleSetVersion) GoString() string {
- return s.String()
- }
- // SetAssociatedRuleGroupArn sets the AssociatedRuleGroupArn field's value.
- func (s *ManagedRuleSetVersion) SetAssociatedRuleGroupArn(v string) *ManagedRuleSetVersion {
- s.AssociatedRuleGroupArn = &v
- return s
- }
- // SetCapacity sets the Capacity field's value.
- func (s *ManagedRuleSetVersion) SetCapacity(v int64) *ManagedRuleSetVersion {
- s.Capacity = &v
- return s
- }
- // SetExpiryTimestamp sets the ExpiryTimestamp field's value.
- func (s *ManagedRuleSetVersion) SetExpiryTimestamp(v time.Time) *ManagedRuleSetVersion {
- s.ExpiryTimestamp = &v
- return s
- }
- // SetForecastedLifetime sets the ForecastedLifetime field's value.
- func (s *ManagedRuleSetVersion) SetForecastedLifetime(v int64) *ManagedRuleSetVersion {
- s.ForecastedLifetime = &v
- return s
- }
- // SetLastUpdateTimestamp sets the LastUpdateTimestamp field's value.
- func (s *ManagedRuleSetVersion) SetLastUpdateTimestamp(v time.Time) *ManagedRuleSetVersion {
- s.LastUpdateTimestamp = &v
- return s
- }
- // SetPublishTimestamp sets the PublishTimestamp field's value.
- func (s *ManagedRuleSetVersion) SetPublishTimestamp(v time.Time) *ManagedRuleSetVersion {
- s.PublishTimestamp = &v
- return s
- }
- // Inspect the HTTP method of the web request. The method indicates the type
- // of operation that the request is asking the origin to perform.
- //
- // This is used only in the FieldToMatch specification for some web request
- // component types.
- //
- // JSON specification: "Method": {}
- type Method struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s Method) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s Method) GoString() string {
- return s.String()
- }
- // Information for a release of the mobile SDK, including release notes and
- // tags.
- //
- // The mobile SDK is not generally available. Customers who have access to the
- // mobile SDK can use it to establish and manage WAF tokens for use in HTTP(S)
- // requests from a mobile device to WAF. For more information, see WAF client
- // application integration (https://docs.aws.amazon.com/waf/latest/developerguide/waf-application-integration.html)
- // in the WAF Developer Guide.
- type MobileSdkRelease struct {
- _ struct{} `type:"structure"`
- // Notes describing the release.
- ReleaseNotes *string `type:"string"`
- // The release version.
- ReleaseVersion *string `min:"1" type:"string"`
- // Tags that are associated with the release.
- Tags []*Tag `min:"1" type:"list"`
- // The timestamp of the release.
- Timestamp *time.Time `type:"timestamp"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s MobileSdkRelease) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s MobileSdkRelease) GoString() string {
- return s.String()
- }
- // SetReleaseNotes sets the ReleaseNotes field's value.
- func (s *MobileSdkRelease) SetReleaseNotes(v string) *MobileSdkRelease {
- s.ReleaseNotes = &v
- return s
- }
- // SetReleaseVersion sets the ReleaseVersion field's value.
- func (s *MobileSdkRelease) SetReleaseVersion(v string) *MobileSdkRelease {
- s.ReleaseVersion = &v
- return s
- }
- // SetTags sets the Tags field's value.
- func (s *MobileSdkRelease) SetTags(v []*Tag) *MobileSdkRelease {
- s.Tags = v
- return s
- }
- // SetTimestamp sets the Timestamp field's value.
- func (s *MobileSdkRelease) SetTimestamp(v time.Time) *MobileSdkRelease {
- s.Timestamp = &v
- return s
- }
- // Specifies that WAF should do nothing. This is used for the OverrideAction
- // setting on a Rule when the rule uses a rule group reference statement.
- //
- // This is used in the context of other settings, for example to specify values
- // for RuleAction and web ACL DefaultAction.
- //
- // JSON specification: "None": {}
- type NoneAction struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s NoneAction) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s NoneAction) GoString() string {
- return s.String()
- }
- // A logical rule statement used to negate the results of another rule statement.
- // You provide one Statement within the NotStatement.
- type NotStatement struct {
- _ struct{} `type:"structure"`
- // The statement to negate. You can use any statement that can be nested.
- //
- // Statement is a required field
- Statement *Statement `type:"structure" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s NotStatement) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s NotStatement) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *NotStatement) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "NotStatement"}
- if s.Statement == nil {
- invalidParams.Add(request.NewErrParamRequired("Statement"))
- }
- if s.Statement != nil {
- if err := s.Statement.Validate(); err != nil {
- invalidParams.AddNested("Statement", err.(request.ErrInvalidParams))
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetStatement sets the Statement field's value.
- func (s *NotStatement) SetStatement(v *Statement) *NotStatement {
- s.Statement = v
- return s
- }
- // A logical rule statement used to combine other rule statements with OR logic.
- // You provide more than one Statement within the OrStatement.
- type OrStatement struct {
- _ struct{} `type:"structure"`
- // The statements to combine with OR logic. You can use any statements that
- // can be nested.
- //
- // Statements is a required field
- Statements []*Statement `type:"list" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s OrStatement) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s OrStatement) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *OrStatement) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "OrStatement"}
- if s.Statements == nil {
- invalidParams.Add(request.NewErrParamRequired("Statements"))
- }
- if s.Statements != nil {
- for i, v := range s.Statements {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "Statements", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetStatements sets the Statements field's value.
- func (s *OrStatement) SetStatements(v []*Statement) *OrStatement {
- s.Statements = v
- return s
- }
- // The action to use in the place of the action that results from the rule group
- // evaluation. Set the override action to none to leave the result of the rule
- // group alone. Set it to count to override the result to count only.
- //
- // You can only use this for rule statements that reference a rule group, like
- // RuleGroupReferenceStatement and ManagedRuleGroupStatement.
- //
- // This option is usually set to none. It does not affect how the rules in the
- // rule group are evaluated. If you want the rules in the rule group to only
- // count matches, do not use this and instead use the rule action override option,
- // with Count action, in your rule group reference statement settings.
- type OverrideAction struct {
- _ struct{} `type:"structure"`
- // Override the rule group evaluation result to count only.
- //
- // This option is usually set to none. It does not affect how the rules in the
- // rule group are evaluated. If you want the rules in the rule group to only
- // count matches, do not use this and instead use the rule action override option,
- // with Count action, in your rule group reference statement settings.
- Count *CountAction `type:"structure"`
- // Don't override the rule group evaluation result. This is the most common
- // setting.
- None *NoneAction `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s OverrideAction) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s OverrideAction) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *OverrideAction) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "OverrideAction"}
- if s.Count != nil {
- if err := s.Count.Validate(); err != nil {
- invalidParams.AddNested("Count", err.(request.ErrInvalidParams))
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetCount sets the Count field's value.
- func (s *OverrideAction) SetCount(v *CountAction) *OverrideAction {
- s.Count = v
- return s
- }
- // SetNone sets the None field's value.
- func (s *OverrideAction) SetNone(v *NoneAction) *OverrideAction {
- s.None = v
- return s
- }
- // Details about your login page password field, used in a ManagedRuleGroupConfig.
- type PasswordField struct {
- _ struct{} `type:"structure"`
- // The name of the password field. For example /form/password.
- //
- // Identifier is a required field
- Identifier *string `min:"1" type:"string" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s PasswordField) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s PasswordField) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *PasswordField) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "PasswordField"}
- if s.Identifier == nil {
- invalidParams.Add(request.NewErrParamRequired("Identifier"))
- }
- if s.Identifier != nil && len(*s.Identifier) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Identifier", 1))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetIdentifier sets the Identifier field's value.
- func (s *PasswordField) SetIdentifier(v string) *PasswordField {
- s.Identifier = &v
- return s
- }
- type PutLoggingConfigurationInput struct {
- _ struct{} `type:"structure"`
- // Defines an association between logging destinations and a web ACL resource,
- // for logging from WAF. As part of the association, you can specify parts of
- // the standard logging fields to keep out of the logs and you can specify filters
- // so that you log only a subset of the logging records.
- //
- // You can define one logging destination per web ACL.
- //
- // You can access information about the traffic that WAF inspects using the
- // following steps:
- //
- // Create your logging destination. You can use an Amazon CloudWatch Logs log
- // group, an Amazon Simple Storage Service (Amazon S3) bucket, or an Amazon
- // Kinesis Data Firehose.
- //
- // The name that you give the destination must start with aws-waf-logs-. Depending
- // on the type of destination, you might need to configure additional settings
- // or permissions.
- //
- // For configuration requirements and pricing information for each destination
- // type, see Logging web ACL traffic (https://docs.aws.amazon.com/waf/latest/developerguide/logging.html)
- // in the WAF Developer Guide.
- //
- // Associate your logging destination to your web ACL using a PutLoggingConfiguration
- // request.
- //
- // When you successfully enable logging using a PutLoggingConfiguration request,
- // WAF creates an additional role or policy that is required to write logs to
- // the logging destination. For an Amazon CloudWatch Logs log group, WAF creates
- // a resource policy on the log group. For an Amazon S3 bucket, WAF creates
- // a bucket policy. For an Amazon Kinesis Data Firehose, WAF creates a service-linked
- // role.
- //
- // For additional information about web ACL logging, see Logging web ACL traffic
- // information (https://docs.aws.amazon.com/waf/latest/developerguide/logging.html)
- // in the WAF Developer Guide.
- //
- // LoggingConfiguration is a required field
- LoggingConfiguration *LoggingConfiguration `type:"structure" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s PutLoggingConfigurationInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s PutLoggingConfigurationInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *PutLoggingConfigurationInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "PutLoggingConfigurationInput"}
- if s.LoggingConfiguration == nil {
- invalidParams.Add(request.NewErrParamRequired("LoggingConfiguration"))
- }
- if s.LoggingConfiguration != nil {
- if err := s.LoggingConfiguration.Validate(); err != nil {
- invalidParams.AddNested("LoggingConfiguration", err.(request.ErrInvalidParams))
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetLoggingConfiguration sets the LoggingConfiguration field's value.
- func (s *PutLoggingConfigurationInput) SetLoggingConfiguration(v *LoggingConfiguration) *PutLoggingConfigurationInput {
- s.LoggingConfiguration = v
- return s
- }
- type PutLoggingConfigurationOutput struct {
- _ struct{} `type:"structure"`
- // Defines an association between logging destinations and a web ACL resource,
- // for logging from WAF. As part of the association, you can specify parts of
- // the standard logging fields to keep out of the logs and you can specify filters
- // so that you log only a subset of the logging records.
- //
- // You can define one logging destination per web ACL.
- //
- // You can access information about the traffic that WAF inspects using the
- // following steps:
- //
- // Create your logging destination. You can use an Amazon CloudWatch Logs log
- // group, an Amazon Simple Storage Service (Amazon S3) bucket, or an Amazon
- // Kinesis Data Firehose.
- //
- // The name that you give the destination must start with aws-waf-logs-. Depending
- // on the type of destination, you might need to configure additional settings
- // or permissions.
- //
- // For configuration requirements and pricing information for each destination
- // type, see Logging web ACL traffic (https://docs.aws.amazon.com/waf/latest/developerguide/logging.html)
- // in the WAF Developer Guide.
- //
- // Associate your logging destination to your web ACL using a PutLoggingConfiguration
- // request.
- //
- // When you successfully enable logging using a PutLoggingConfiguration request,
- // WAF creates an additional role or policy that is required to write logs to
- // the logging destination. For an Amazon CloudWatch Logs log group, WAF creates
- // a resource policy on the log group. For an Amazon S3 bucket, WAF creates
- // a bucket policy. For an Amazon Kinesis Data Firehose, WAF creates a service-linked
- // role.
- //
- // For additional information about web ACL logging, see Logging web ACL traffic
- // information (https://docs.aws.amazon.com/waf/latest/developerguide/logging.html)
- // in the WAF Developer Guide.
- LoggingConfiguration *LoggingConfiguration `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s PutLoggingConfigurationOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s PutLoggingConfigurationOutput) GoString() string {
- return s.String()
- }
- // SetLoggingConfiguration sets the LoggingConfiguration field's value.
- func (s *PutLoggingConfigurationOutput) SetLoggingConfiguration(v *LoggingConfiguration) *PutLoggingConfigurationOutput {
- s.LoggingConfiguration = v
- return s
- }
- type PutManagedRuleSetVersionsInput struct {
- _ struct{} `type:"structure"`
- // A unique identifier for the managed rule set. The ID is returned in the responses
- // to commands like list. You provide it to operations like get and update.
- //
- // Id is a required field
- Id *string `min:"1" type:"string" required:"true"`
- // A token used for optimistic locking. WAF returns a token to your get and
- // list requests, to mark the state of the entity at the time of the request.
- // To make changes to the entity associated with the token, you provide the
- // token to operations like update and delete. WAF uses the token to ensure
- // that no changes have been made to the entity since you last retrieved it.
- // If a change has been made, the update fails with a WAFOptimisticLockException.
- // If this happens, perform another get, and use the new token returned by that
- // operation.
- //
- // LockToken is a required field
- LockToken *string `min:"1" type:"string" required:"true"`
- // The name of the managed rule set. You use this, along with the rule set ID,
- // to identify the rule set.
- //
- // This name is assigned to the corresponding managed rule group, which your
- // customers can access and use.
- //
- // Name is a required field
- Name *string `min:"1" type:"string" required:"true"`
- // The version of the named managed rule group that you'd like your customers
- // to choose, from among your version offerings.
- RecommendedVersion *string `min:"1" type:"string"`
- // Specifies whether this is for an Amazon CloudFront distribution or for a
- // regional application. A regional application can be an Application Load Balancer
- // (ALB), an Amazon API Gateway REST API, an AppSync GraphQL API, or an Amazon
- // Cognito user pool.
- //
- // To work with CloudFront, you must also specify the Region US East (N. Virginia)
- // as follows:
- //
- // * CLI - Specify the Region when you use the CloudFront scope: --scope=CLOUDFRONT
- // --region=us-east-1.
- //
- // * API and SDKs - For all calls, use the Region endpoint us-east-1.
- //
- // Scope is a required field
- Scope *string `type:"string" required:"true" enum:"Scope"`
- // The versions of the named managed rule group that you want to offer to your
- // customers.
- VersionsToPublish map[string]*VersionToPublish `type:"map"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s PutManagedRuleSetVersionsInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s PutManagedRuleSetVersionsInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *PutManagedRuleSetVersionsInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "PutManagedRuleSetVersionsInput"}
- if s.Id == nil {
- invalidParams.Add(request.NewErrParamRequired("Id"))
- }
- if s.Id != nil && len(*s.Id) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Id", 1))
- }
- if s.LockToken == nil {
- invalidParams.Add(request.NewErrParamRequired("LockToken"))
- }
- if s.LockToken != nil && len(*s.LockToken) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("LockToken", 1))
- }
- if s.Name == nil {
- invalidParams.Add(request.NewErrParamRequired("Name"))
- }
- if s.Name != nil && len(*s.Name) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Name", 1))
- }
- if s.RecommendedVersion != nil && len(*s.RecommendedVersion) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("RecommendedVersion", 1))
- }
- if s.Scope == nil {
- invalidParams.Add(request.NewErrParamRequired("Scope"))
- }
- if s.VersionsToPublish != nil {
- for i, v := range s.VersionsToPublish {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "VersionsToPublish", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetId sets the Id field's value.
- func (s *PutManagedRuleSetVersionsInput) SetId(v string) *PutManagedRuleSetVersionsInput {
- s.Id = &v
- return s
- }
- // SetLockToken sets the LockToken field's value.
- func (s *PutManagedRuleSetVersionsInput) SetLockToken(v string) *PutManagedRuleSetVersionsInput {
- s.LockToken = &v
- return s
- }
- // SetName sets the Name field's value.
- func (s *PutManagedRuleSetVersionsInput) SetName(v string) *PutManagedRuleSetVersionsInput {
- s.Name = &v
- return s
- }
- // SetRecommendedVersion sets the RecommendedVersion field's value.
- func (s *PutManagedRuleSetVersionsInput) SetRecommendedVersion(v string) *PutManagedRuleSetVersionsInput {
- s.RecommendedVersion = &v
- return s
- }
- // SetScope sets the Scope field's value.
- func (s *PutManagedRuleSetVersionsInput) SetScope(v string) *PutManagedRuleSetVersionsInput {
- s.Scope = &v
- return s
- }
- // SetVersionsToPublish sets the VersionsToPublish field's value.
- func (s *PutManagedRuleSetVersionsInput) SetVersionsToPublish(v map[string]*VersionToPublish) *PutManagedRuleSetVersionsInput {
- s.VersionsToPublish = v
- return s
- }
- type PutManagedRuleSetVersionsOutput struct {
- _ struct{} `type:"structure"`
- // A token used for optimistic locking. WAF returns a token to your get and
- // list requests, to mark the state of the entity at the time of the request.
- // To make changes to the entity associated with the token, you provide the
- // token to operations like update and delete. WAF uses the token to ensure
- // that no changes have been made to the entity since you last retrieved it.
- // If a change has been made, the update fails with a WAFOptimisticLockException.
- // If this happens, perform another get, and use the new token returned by that
- // operation.
- NextLockToken *string `min:"1" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s PutManagedRuleSetVersionsOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s PutManagedRuleSetVersionsOutput) GoString() string {
- return s.String()
- }
- // SetNextLockToken sets the NextLockToken field's value.
- func (s *PutManagedRuleSetVersionsOutput) SetNextLockToken(v string) *PutManagedRuleSetVersionsOutput {
- s.NextLockToken = &v
- return s
- }
- type PutPermissionPolicyInput struct {
- _ struct{} `type:"structure"`
- // The policy to attach to the specified rule group.
- //
- // The policy specifications must conform to the following:
- //
- // * The policy must be composed using IAM Policy version 2012-10-17 or version
- // 2015-01-01.
- //
- // * The policy must include specifications for Effect, Action, and Principal.
- //
- // * Effect must specify Allow.
- //
- // * Action must specify wafv2:CreateWebACL, wafv2:UpdateWebACL, and wafv2:PutFirewallManagerRuleGroups
- // and may optionally specify wafv2:GetRuleGroup. WAF rejects any extra actions
- // or wildcard actions in the policy.
- //
- // * The policy must not include a Resource parameter.
- //
- // For more information, see IAM Policies (https://docs.aws.amazon.com/IAM/latest/UserGuide/access_policies.html).
- //
- // Policy is a required field
- Policy *string `min:"1" type:"string" required:"true"`
- // The Amazon Resource Name (ARN) of the RuleGroup to which you want to attach
- // the policy.
- //
- // ResourceArn is a required field
- ResourceArn *string `min:"20" type:"string" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s PutPermissionPolicyInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s PutPermissionPolicyInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *PutPermissionPolicyInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "PutPermissionPolicyInput"}
- if s.Policy == nil {
- invalidParams.Add(request.NewErrParamRequired("Policy"))
- }
- if s.Policy != nil && len(*s.Policy) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Policy", 1))
- }
- if s.ResourceArn == nil {
- invalidParams.Add(request.NewErrParamRequired("ResourceArn"))
- }
- if s.ResourceArn != nil && len(*s.ResourceArn) < 20 {
- invalidParams.Add(request.NewErrParamMinLen("ResourceArn", 20))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetPolicy sets the Policy field's value.
- func (s *PutPermissionPolicyInput) SetPolicy(v string) *PutPermissionPolicyInput {
- s.Policy = &v
- return s
- }
- // SetResourceArn sets the ResourceArn field's value.
- func (s *PutPermissionPolicyInput) SetResourceArn(v string) *PutPermissionPolicyInput {
- s.ResourceArn = &v
- return s
- }
- type PutPermissionPolicyOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s PutPermissionPolicyOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s PutPermissionPolicyOutput) GoString() string {
- return s.String()
- }
- // Inspect the query string of the web request. This is the part of a URL that
- // appears after a ? character, if any.
- //
- // This is used only in the FieldToMatch specification for some web request
- // component types.
- //
- // JSON specification: "QueryString": {}
- type QueryString struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s QueryString) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s QueryString) GoString() string {
- return s.String()
- }
- // A rate-based rule tracks the rate of requests for each originating IP address,
- // and triggers the rule action when the rate exceeds a limit that you specify
- // on the number of requests in any 5-minute time span. You can use this to
- // put a temporary block on requests from an IP address that is sending excessive
- // requests.
- //
- // WAF tracks and manages web requests separately for each instance of a rate-based
- // rule that you use. For example, if you provide the same rate-based rule settings
- // in two web ACLs, each of the two rule statements represents a separate instance
- // of the rate-based rule and gets its own tracking and management by WAF. If
- // you define a rate-based rule inside a rule group, and then use that rule
- // group in multiple places, each use creates a separate instance of the rate-based
- // rule that gets its own tracking and management by WAF.
- //
- // When the rule action triggers, WAF blocks additional requests from the IP
- // address until the request rate falls below the limit.
- //
- // You can optionally nest another statement inside the rate-based statement,
- // to narrow the scope of the rule so that it only counts requests that match
- // the nested statement. For example, based on recent requests that you have
- // seen from an attacker, you might create a rate-based rule with a nested AND
- // rule statement that contains the following nested statements:
- //
- // - An IP match statement with an IP set that specified the address 192.0.2.44.
- //
- // - A string match statement that searches in the User-Agent header for
- // the string BadBot.
- //
- // In this rate-based rule, you also define a rate limit. For this example,
- // the rate limit is 1,000. Requests that meet the criteria of both of the nested
- // statements are counted. If the count exceeds 1,000 requests per five minutes,
- // the rule action triggers. Requests that do not meet the criteria of both
- // of the nested statements are not counted towards the rate limit and are not
- // affected by this rule.
- //
- // You cannot nest a RateBasedStatement inside another statement, for example
- // inside a NotStatement or OrStatement. You can define a RateBasedStatement
- // inside a web ACL and inside a rule group.
- type RateBasedStatement struct {
- _ struct{} `type:"structure"`
- // Setting that indicates how to aggregate the request counts. The options are
- // the following:
- //
- // * IP - Aggregate the request counts on the IP address from the web request
- // origin.
- //
- // * FORWARDED_IP - Aggregate the request counts on the first IP address
- // in an HTTP header. If you use this, configure the ForwardedIPConfig, to
- // specify the header to use.
- //
- // AggregateKeyType is a required field
- AggregateKeyType *string `type:"string" required:"true" enum:"RateBasedStatementAggregateKeyType"`
- // The configuration for inspecting IP addresses in an HTTP header that you
- // specify, instead of using the IP address that's reported by the web request
- // origin. Commonly, this is the X-Forwarded-For (XFF) header, but you can specify
- // any header name.
- //
- // If the specified header isn't present in the request, WAF doesn't apply the
- // rule to the web request at all.
- //
- // This is required if AggregateKeyType is set to FORWARDED_IP.
- ForwardedIPConfig *ForwardedIPConfig `type:"structure"`
- // The limit on requests per 5-minute period for a single originating IP address.
- // If the statement includes a ScopeDownStatement, this limit is applied only
- // to the requests that match the statement.
- //
- // Limit is a required field
- Limit *int64 `min:"100" type:"long" required:"true"`
- // An optional nested statement that narrows the scope of the web requests that
- // are evaluated by the rate-based statement. Requests are only tracked by the
- // rate-based statement if they match the scope-down statement. You can use
- // any nestable Statement in the scope-down statement, and you can nest statements
- // at any level, the same as you can for a rule statement.
- ScopeDownStatement *Statement `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s RateBasedStatement) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s RateBasedStatement) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *RateBasedStatement) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "RateBasedStatement"}
- if s.AggregateKeyType == nil {
- invalidParams.Add(request.NewErrParamRequired("AggregateKeyType"))
- }
- if s.Limit == nil {
- invalidParams.Add(request.NewErrParamRequired("Limit"))
- }
- if s.Limit != nil && *s.Limit < 100 {
- invalidParams.Add(request.NewErrParamMinValue("Limit", 100))
- }
- if s.ForwardedIPConfig != nil {
- if err := s.ForwardedIPConfig.Validate(); err != nil {
- invalidParams.AddNested("ForwardedIPConfig", err.(request.ErrInvalidParams))
- }
- }
- if s.ScopeDownStatement != nil {
- if err := s.ScopeDownStatement.Validate(); err != nil {
- invalidParams.AddNested("ScopeDownStatement", err.(request.ErrInvalidParams))
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetAggregateKeyType sets the AggregateKeyType field's value.
- func (s *RateBasedStatement) SetAggregateKeyType(v string) *RateBasedStatement {
- s.AggregateKeyType = &v
- return s
- }
- // SetForwardedIPConfig sets the ForwardedIPConfig field's value.
- func (s *RateBasedStatement) SetForwardedIPConfig(v *ForwardedIPConfig) *RateBasedStatement {
- s.ForwardedIPConfig = v
- return s
- }
- // SetLimit sets the Limit field's value.
- func (s *RateBasedStatement) SetLimit(v int64) *RateBasedStatement {
- s.Limit = &v
- return s
- }
- // SetScopeDownStatement sets the ScopeDownStatement field's value.
- func (s *RateBasedStatement) SetScopeDownStatement(v *Statement) *RateBasedStatement {
- s.ScopeDownStatement = v
- return s
- }
- // The set of IP addresses that are currently blocked for a RateBasedStatement.
- type RateBasedStatementManagedKeysIPSet struct {
- _ struct{} `type:"structure"`
- // The IP addresses that are currently blocked.
- Addresses []*string `type:"list"`
- // The version of the IP addresses, either IPV4 or IPV6.
- IPAddressVersion *string `type:"string" enum:"IPAddressVersion"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s RateBasedStatementManagedKeysIPSet) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s RateBasedStatementManagedKeysIPSet) GoString() string {
- return s.String()
- }
- // SetAddresses sets the Addresses field's value.
- func (s *RateBasedStatementManagedKeysIPSet) SetAddresses(v []*string) *RateBasedStatementManagedKeysIPSet {
- s.Addresses = v
- return s
- }
- // SetIPAddressVersion sets the IPAddressVersion field's value.
- func (s *RateBasedStatementManagedKeysIPSet) SetIPAddressVersion(v string) *RateBasedStatementManagedKeysIPSet {
- s.IPAddressVersion = &v
- return s
- }
- // A single regular expression. This is used in a RegexPatternSet.
- type Regex struct {
- _ struct{} `type:"structure"`
- // The string representing the regular expression.
- RegexString *string `min:"1" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s Regex) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s Regex) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *Regex) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "Regex"}
- if s.RegexString != nil && len(*s.RegexString) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("RegexString", 1))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetRegexString sets the RegexString field's value.
- func (s *Regex) SetRegexString(v string) *Regex {
- s.RegexString = &v
- return s
- }
- // A rule statement used to search web request components for a match against
- // a single regular expression.
- type RegexMatchStatement struct {
- _ struct{} `type:"structure"`
- // The part of the web request that you want WAF to inspect.
- //
- // FieldToMatch is a required field
- FieldToMatch *FieldToMatch `type:"structure" required:"true"`
- // The string representing the regular expression.
- //
- // RegexString is a required field
- RegexString *string `min:"1" type:"string" required:"true"`
- // Text transformations eliminate some of the unusual formatting that attackers
- // use in web requests in an effort to bypass detection. If you specify one
- // or more transformations in a rule statement, WAF performs all transformations
- // on the content of the request component identified by FieldToMatch, starting
- // from the lowest priority setting, before inspecting the content for a match.
- //
- // TextTransformations is a required field
- TextTransformations []*TextTransformation `min:"1" type:"list" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s RegexMatchStatement) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s RegexMatchStatement) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *RegexMatchStatement) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "RegexMatchStatement"}
- if s.FieldToMatch == nil {
- invalidParams.Add(request.NewErrParamRequired("FieldToMatch"))
- }
- if s.RegexString == nil {
- invalidParams.Add(request.NewErrParamRequired("RegexString"))
- }
- if s.RegexString != nil && len(*s.RegexString) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("RegexString", 1))
- }
- if s.TextTransformations == nil {
- invalidParams.Add(request.NewErrParamRequired("TextTransformations"))
- }
- if s.TextTransformations != nil && len(s.TextTransformations) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("TextTransformations", 1))
- }
- if s.FieldToMatch != nil {
- if err := s.FieldToMatch.Validate(); err != nil {
- invalidParams.AddNested("FieldToMatch", err.(request.ErrInvalidParams))
- }
- }
- if s.TextTransformations != nil {
- for i, v := range s.TextTransformations {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "TextTransformations", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetFieldToMatch sets the FieldToMatch field's value.
- func (s *RegexMatchStatement) SetFieldToMatch(v *FieldToMatch) *RegexMatchStatement {
- s.FieldToMatch = v
- return s
- }
- // SetRegexString sets the RegexString field's value.
- func (s *RegexMatchStatement) SetRegexString(v string) *RegexMatchStatement {
- s.RegexString = &v
- return s
- }
- // SetTextTransformations sets the TextTransformations field's value.
- func (s *RegexMatchStatement) SetTextTransformations(v []*TextTransformation) *RegexMatchStatement {
- s.TextTransformations = v
- return s
- }
- // Contains one or more regular expressions.
- //
- // WAF assigns an ARN to each RegexPatternSet that you create. To use a set
- // in a rule, you provide the ARN to the Rule statement RegexPatternSetReferenceStatement.
- type RegexPatternSet struct {
- _ struct{} `type:"structure"`
- // The Amazon Resource Name (ARN) of the entity.
- ARN *string `min:"20" type:"string"`
- // A description of the set that helps with identification.
- Description *string `min:"1" type:"string"`
- // A unique identifier for the set. This ID is returned in the responses to
- // create and list commands. You provide it to operations like update and delete.
- Id *string `min:"1" type:"string"`
- // The name of the set. You cannot change the name after you create the set.
- Name *string `min:"1" type:"string"`
- // The regular expression patterns in the set.
- RegularExpressionList []*Regex `type:"list"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s RegexPatternSet) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s RegexPatternSet) GoString() string {
- return s.String()
- }
- // SetARN sets the ARN field's value.
- func (s *RegexPatternSet) SetARN(v string) *RegexPatternSet {
- s.ARN = &v
- return s
- }
- // SetDescription sets the Description field's value.
- func (s *RegexPatternSet) SetDescription(v string) *RegexPatternSet {
- s.Description = &v
- return s
- }
- // SetId sets the Id field's value.
- func (s *RegexPatternSet) SetId(v string) *RegexPatternSet {
- s.Id = &v
- return s
- }
- // SetName sets the Name field's value.
- func (s *RegexPatternSet) SetName(v string) *RegexPatternSet {
- s.Name = &v
- return s
- }
- // SetRegularExpressionList sets the RegularExpressionList field's value.
- func (s *RegexPatternSet) SetRegularExpressionList(v []*Regex) *RegexPatternSet {
- s.RegularExpressionList = v
- return s
- }
- // A rule statement used to search web request components for matches with regular
- // expressions. To use this, create a RegexPatternSet that specifies the expressions
- // that you want to detect, then use the ARN of that set in this statement.
- // A web request matches the pattern set rule statement if the request component
- // matches any of the patterns in the set. To create a regex pattern set, see
- // CreateRegexPatternSet.
- //
- // Each regex pattern set rule statement references a regex pattern set. You
- // create and maintain the set independent of your rules. This allows you to
- // use the single set in multiple rules. When you update the referenced set,
- // WAF automatically updates all rules that reference it.
- type RegexPatternSetReferenceStatement struct {
- _ struct{} `type:"structure"`
- // The Amazon Resource Name (ARN) of the RegexPatternSet that this statement
- // references.
- //
- // ARN is a required field
- ARN *string `min:"20" type:"string" required:"true"`
- // The part of the web request that you want WAF to inspect.
- //
- // FieldToMatch is a required field
- FieldToMatch *FieldToMatch `type:"structure" required:"true"`
- // Text transformations eliminate some of the unusual formatting that attackers
- // use in web requests in an effort to bypass detection. If you specify one
- // or more transformations in a rule statement, WAF performs all transformations
- // on the content of the request component identified by FieldToMatch, starting
- // from the lowest priority setting, before inspecting the content for a match.
- //
- // TextTransformations is a required field
- TextTransformations []*TextTransformation `min:"1" type:"list" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s RegexPatternSetReferenceStatement) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s RegexPatternSetReferenceStatement) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *RegexPatternSetReferenceStatement) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "RegexPatternSetReferenceStatement"}
- if s.ARN == nil {
- invalidParams.Add(request.NewErrParamRequired("ARN"))
- }
- if s.ARN != nil && len(*s.ARN) < 20 {
- invalidParams.Add(request.NewErrParamMinLen("ARN", 20))
- }
- if s.FieldToMatch == nil {
- invalidParams.Add(request.NewErrParamRequired("FieldToMatch"))
- }
- if s.TextTransformations == nil {
- invalidParams.Add(request.NewErrParamRequired("TextTransformations"))
- }
- if s.TextTransformations != nil && len(s.TextTransformations) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("TextTransformations", 1))
- }
- if s.FieldToMatch != nil {
- if err := s.FieldToMatch.Validate(); err != nil {
- invalidParams.AddNested("FieldToMatch", err.(request.ErrInvalidParams))
- }
- }
- if s.TextTransformations != nil {
- for i, v := range s.TextTransformations {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "TextTransformations", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetARN sets the ARN field's value.
- func (s *RegexPatternSetReferenceStatement) SetARN(v string) *RegexPatternSetReferenceStatement {
- s.ARN = &v
- return s
- }
- // SetFieldToMatch sets the FieldToMatch field's value.
- func (s *RegexPatternSetReferenceStatement) SetFieldToMatch(v *FieldToMatch) *RegexPatternSetReferenceStatement {
- s.FieldToMatch = v
- return s
- }
- // SetTextTransformations sets the TextTransformations field's value.
- func (s *RegexPatternSetReferenceStatement) SetTextTransformations(v []*TextTransformation) *RegexPatternSetReferenceStatement {
- s.TextTransformations = v
- return s
- }
- // High-level information about a RegexPatternSet, returned by operations like
- // create and list. This provides information like the ID, that you can use
- // to retrieve and manage a RegexPatternSet, and the ARN, that you provide to
- // the RegexPatternSetReferenceStatement to use the pattern set in a Rule.
- type RegexPatternSetSummary struct {
- _ struct{} `type:"structure"`
- // The Amazon Resource Name (ARN) of the entity.
- ARN *string `min:"20" type:"string"`
- // A description of the set that helps with identification.
- Description *string `min:"1" type:"string"`
- // A unique identifier for the set. This ID is returned in the responses to
- // create and list commands. You provide it to operations like update and delete.
- Id *string `min:"1" type:"string"`
- // A token used for optimistic locking. WAF returns a token to your get and
- // list requests, to mark the state of the entity at the time of the request.
- // To make changes to the entity associated with the token, you provide the
- // token to operations like update and delete. WAF uses the token to ensure
- // that no changes have been made to the entity since you last retrieved it.
- // If a change has been made, the update fails with a WAFOptimisticLockException.
- // If this happens, perform another get, and use the new token returned by that
- // operation.
- LockToken *string `min:"1" type:"string"`
- // The name of the data type instance. You cannot change the name after you
- // create the instance.
- Name *string `min:"1" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s RegexPatternSetSummary) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s RegexPatternSetSummary) GoString() string {
- return s.String()
- }
- // SetARN sets the ARN field's value.
- func (s *RegexPatternSetSummary) SetARN(v string) *RegexPatternSetSummary {
- s.ARN = &v
- return s
- }
- // SetDescription sets the Description field's value.
- func (s *RegexPatternSetSummary) SetDescription(v string) *RegexPatternSetSummary {
- s.Description = &v
- return s
- }
- // SetId sets the Id field's value.
- func (s *RegexPatternSetSummary) SetId(v string) *RegexPatternSetSummary {
- s.Id = &v
- return s
- }
- // SetLockToken sets the LockToken field's value.
- func (s *RegexPatternSetSummary) SetLockToken(v string) *RegexPatternSetSummary {
- s.LockToken = &v
- return s
- }
- // SetName sets the Name field's value.
- func (s *RegexPatternSetSummary) SetName(v string) *RegexPatternSetSummary {
- s.Name = &v
- return s
- }
- // High level information for an SDK release.
- type ReleaseSummary struct {
- _ struct{} `type:"structure"`
- // The release version.
- ReleaseVersion *string `min:"1" type:"string"`
- // The timestamp of the release.
- Timestamp *time.Time `type:"timestamp"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ReleaseSummary) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s ReleaseSummary) GoString() string {
- return s.String()
- }
- // SetReleaseVersion sets the ReleaseVersion field's value.
- func (s *ReleaseSummary) SetReleaseVersion(v string) *ReleaseSummary {
- s.ReleaseVersion = &v
- return s
- }
- // SetTimestamp sets the Timestamp field's value.
- func (s *ReleaseSummary) SetTimestamp(v time.Time) *ReleaseSummary {
- s.Timestamp = &v
- return s
- }
- // A single rule, which you can use in a WebACL or RuleGroup to identify web
- // requests that you want to allow, block, or count. Each rule includes one
- // top-level Statement that WAF uses to identify matching web requests, and
- // parameters that govern how WAF handles them.
- type Rule struct {
- _ struct{} `type:"structure"`
- // The action that WAF should take on a web request when it matches the rule
- // statement. Settings at the web ACL level can override the rule action setting.
- //
- // This is used only for rules whose statements do not reference a rule group.
- // Rule statements that reference a rule group include RuleGroupReferenceStatement
- // and ManagedRuleGroupStatement.
- //
- // You must specify either this Action setting or the rule OverrideAction setting,
- // but not both:
- //
- // * If the rule statement does not reference a rule group, use this rule
- // action setting and not the rule override action setting.
- //
- // * If the rule statement references a rule group, use the override action
- // setting and not this action setting.
- Action *RuleAction `type:"structure"`
- // Specifies how WAF should handle CAPTCHA evaluations. If you don't specify
- // this, WAF uses the CAPTCHA configuration that's defined for the web ACL.
- CaptchaConfig *CaptchaConfig `type:"structure"`
- // Specifies how WAF should handle Challenge evaluations. If you don't specify
- // this, WAF uses the challenge configuration that's defined for the web ACL.
- ChallengeConfig *ChallengeConfig `type:"structure"`
- // The name of the rule. You can't change the name of a Rule after you create
- // it.
- //
- // Name is a required field
- Name *string `min:"1" type:"string" required:"true"`
- // The action to use in the place of the action that results from the rule group
- // evaluation. Set the override action to none to leave the result of the rule
- // group alone. Set it to count to override the result to count only.
- //
- // You can only use this for rule statements that reference a rule group, like
- // RuleGroupReferenceStatement and ManagedRuleGroupStatement.
- //
- // This option is usually set to none. It does not affect how the rules in the
- // rule group are evaluated. If you want the rules in the rule group to only
- // count matches, do not use this and instead use the rule action override option,
- // with Count action, in your rule group reference statement settings.
- OverrideAction *OverrideAction `type:"structure"`
- // If you define more than one Rule in a WebACL, WAF evaluates each request
- // against the Rules in order based on the value of Priority. WAF processes
- // rules with lower priority first. The priorities don't need to be consecutive,
- // but they must all be different.
- //
- // Priority is a required field
- Priority *int64 `type:"integer" required:"true"`
- // Labels to apply to web requests that match the rule match statement. WAF
- // applies fully qualified labels to matching web requests. A fully qualified
- // label is the concatenation of a label namespace and a rule label. The rule's
- // rule group or web ACL defines the label namespace.
- //
- // Rules that run after this rule in the web ACL can match against these labels
- // using a LabelMatchStatement.
- //
- // For each label, provide a case-sensitive string containing optional namespaces
- // and a label name, according to the following guidelines:
- //
- // * Separate each component of the label with a colon.
- //
- // * Each namespace or name can have up to 128 characters.
- //
- // * You can specify up to 5 namespaces in a label.
- //
- // * Don't use the following reserved words in your label specification:
- // aws, waf, managed, rulegroup, webacl, regexpatternset, or ipset.
- //
- // For example, myLabelName or nameSpace1:nameSpace2:myLabelName.
- RuleLabels []*Label `type:"list"`
- // The WAF processing statement for the rule, for example ByteMatchStatement
- // or SizeConstraintStatement.
- //
- // Statement is a required field
- Statement *Statement `type:"structure" required:"true"`
- // Defines and enables Amazon CloudWatch metrics and web request sample collection.
- //
- // VisibilityConfig is a required field
- VisibilityConfig *VisibilityConfig `type:"structure" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s Rule) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s Rule) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *Rule) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "Rule"}
- if s.Name == nil {
- invalidParams.Add(request.NewErrParamRequired("Name"))
- }
- if s.Name != nil && len(*s.Name) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Name", 1))
- }
- if s.Priority == nil {
- invalidParams.Add(request.NewErrParamRequired("Priority"))
- }
- if s.Statement == nil {
- invalidParams.Add(request.NewErrParamRequired("Statement"))
- }
- if s.VisibilityConfig == nil {
- invalidParams.Add(request.NewErrParamRequired("VisibilityConfig"))
- }
- if s.Action != nil {
- if err := s.Action.Validate(); err != nil {
- invalidParams.AddNested("Action", err.(request.ErrInvalidParams))
- }
- }
- if s.CaptchaConfig != nil {
- if err := s.CaptchaConfig.Validate(); err != nil {
- invalidParams.AddNested("CaptchaConfig", err.(request.ErrInvalidParams))
- }
- }
- if s.ChallengeConfig != nil {
- if err := s.ChallengeConfig.Validate(); err != nil {
- invalidParams.AddNested("ChallengeConfig", err.(request.ErrInvalidParams))
- }
- }
- if s.OverrideAction != nil {
- if err := s.OverrideAction.Validate(); err != nil {
- invalidParams.AddNested("OverrideAction", err.(request.ErrInvalidParams))
- }
- }
- if s.RuleLabels != nil {
- for i, v := range s.RuleLabels {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "RuleLabels", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if s.Statement != nil {
- if err := s.Statement.Validate(); err != nil {
- invalidParams.AddNested("Statement", err.(request.ErrInvalidParams))
- }
- }
- if s.VisibilityConfig != nil {
- if err := s.VisibilityConfig.Validate(); err != nil {
- invalidParams.AddNested("VisibilityConfig", err.(request.ErrInvalidParams))
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetAction sets the Action field's value.
- func (s *Rule) SetAction(v *RuleAction) *Rule {
- s.Action = v
- return s
- }
- // SetCaptchaConfig sets the CaptchaConfig field's value.
- func (s *Rule) SetCaptchaConfig(v *CaptchaConfig) *Rule {
- s.CaptchaConfig = v
- return s
- }
- // SetChallengeConfig sets the ChallengeConfig field's value.
- func (s *Rule) SetChallengeConfig(v *ChallengeConfig) *Rule {
- s.ChallengeConfig = v
- return s
- }
- // SetName sets the Name field's value.
- func (s *Rule) SetName(v string) *Rule {
- s.Name = &v
- return s
- }
- // SetOverrideAction sets the OverrideAction field's value.
- func (s *Rule) SetOverrideAction(v *OverrideAction) *Rule {
- s.OverrideAction = v
- return s
- }
- // SetPriority sets the Priority field's value.
- func (s *Rule) SetPriority(v int64) *Rule {
- s.Priority = &v
- return s
- }
- // SetRuleLabels sets the RuleLabels field's value.
- func (s *Rule) SetRuleLabels(v []*Label) *Rule {
- s.RuleLabels = v
- return s
- }
- // SetStatement sets the Statement field's value.
- func (s *Rule) SetStatement(v *Statement) *Rule {
- s.Statement = v
- return s
- }
- // SetVisibilityConfig sets the VisibilityConfig field's value.
- func (s *Rule) SetVisibilityConfig(v *VisibilityConfig) *Rule {
- s.VisibilityConfig = v
- return s
- }
- // The action that WAF should take on a web request when it matches a rule's
- // statement. Settings at the web ACL level can override the rule action setting.
- type RuleAction struct {
- _ struct{} `type:"structure"`
- // Instructs WAF to allow the web request.
- Allow *AllowAction `type:"structure"`
- // Instructs WAF to block the web request.
- Block *BlockAction `type:"structure"`
- // Instructs WAF to run a CAPTCHA check against the web request.
- Captcha *CaptchaAction `type:"structure"`
- // Instructs WAF to run a Challenge check against the web request.
- Challenge *ChallengeAction `type:"structure"`
- // Instructs WAF to count the web request and then continue evaluating the request
- // using the remaining rules in the web ACL.
- Count *CountAction `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s RuleAction) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s RuleAction) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *RuleAction) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "RuleAction"}
- if s.Allow != nil {
- if err := s.Allow.Validate(); err != nil {
- invalidParams.AddNested("Allow", err.(request.ErrInvalidParams))
- }
- }
- if s.Block != nil {
- if err := s.Block.Validate(); err != nil {
- invalidParams.AddNested("Block", err.(request.ErrInvalidParams))
- }
- }
- if s.Captcha != nil {
- if err := s.Captcha.Validate(); err != nil {
- invalidParams.AddNested("Captcha", err.(request.ErrInvalidParams))
- }
- }
- if s.Challenge != nil {
- if err := s.Challenge.Validate(); err != nil {
- invalidParams.AddNested("Challenge", err.(request.ErrInvalidParams))
- }
- }
- if s.Count != nil {
- if err := s.Count.Validate(); err != nil {
- invalidParams.AddNested("Count", err.(request.ErrInvalidParams))
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetAllow sets the Allow field's value.
- func (s *RuleAction) SetAllow(v *AllowAction) *RuleAction {
- s.Allow = v
- return s
- }
- // SetBlock sets the Block field's value.
- func (s *RuleAction) SetBlock(v *BlockAction) *RuleAction {
- s.Block = v
- return s
- }
- // SetCaptcha sets the Captcha field's value.
- func (s *RuleAction) SetCaptcha(v *CaptchaAction) *RuleAction {
- s.Captcha = v
- return s
- }
- // SetChallenge sets the Challenge field's value.
- func (s *RuleAction) SetChallenge(v *ChallengeAction) *RuleAction {
- s.Challenge = v
- return s
- }
- // SetCount sets the Count field's value.
- func (s *RuleAction) SetCount(v *CountAction) *RuleAction {
- s.Count = v
- return s
- }
- // Action setting to use in the place of a rule action that is configured inside
- // the rule group. You specify one override for each rule whose action you want
- // to change.
- //
- // You can use overrides for testing, for example you can override all of rule
- // actions to Count and then monitor the resulting count metrics to understand
- // how the rule group would handle your web traffic. You can also permanently
- // override some or all actions, to modify how the rule group manages your web
- // traffic.
- type RuleActionOverride struct {
- _ struct{} `type:"structure"`
- // The override action to use, in place of the configured action of the rule
- // in the rule group.
- //
- // ActionToUse is a required field
- ActionToUse *RuleAction `type:"structure" required:"true"`
- // The name of the rule to override.
- //
- // Name is a required field
- Name *string `min:"1" type:"string" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s RuleActionOverride) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s RuleActionOverride) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *RuleActionOverride) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "RuleActionOverride"}
- if s.ActionToUse == nil {
- invalidParams.Add(request.NewErrParamRequired("ActionToUse"))
- }
- if s.Name == nil {
- invalidParams.Add(request.NewErrParamRequired("Name"))
- }
- if s.Name != nil && len(*s.Name) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Name", 1))
- }
- if s.ActionToUse != nil {
- if err := s.ActionToUse.Validate(); err != nil {
- invalidParams.AddNested("ActionToUse", err.(request.ErrInvalidParams))
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetActionToUse sets the ActionToUse field's value.
- func (s *RuleActionOverride) SetActionToUse(v *RuleAction) *RuleActionOverride {
- s.ActionToUse = v
- return s
- }
- // SetName sets the Name field's value.
- func (s *RuleActionOverride) SetName(v string) *RuleActionOverride {
- s.Name = &v
- return s
- }
- // A rule group defines a collection of rules to inspect and control web requests
- // that you can use in a WebACL. When you create a rule group, you define an
- // immutable capacity limit. If you update a rule group, you must stay within
- // the capacity. This allows others to reuse the rule group with confidence
- // in its capacity requirements.
- type RuleGroup struct {
- _ struct{} `type:"structure"`
- // The Amazon Resource Name (ARN) of the entity.
- //
- // ARN is a required field
- ARN *string `min:"20" type:"string" required:"true"`
- // The labels that one or more rules in this rule group add to matching web
- // requests. These labels are defined in the RuleLabels for a Rule.
- AvailableLabels []*LabelSummary `type:"list"`
- // The web ACL capacity units (WCUs) required for this rule group.
- //
- // When you create your own rule group, you define this, and you cannot change
- // it after creation. When you add or modify the rules in a rule group, WAF
- // enforces this limit. You can check the capacity for a set of rules using
- // CheckCapacity.
- //
- // WAF uses WCUs to calculate and control the operating resources that are used
- // to run your rules, rule groups, and web ACLs. WAF calculates capacity differently
- // for each rule type, to reflect the relative cost of each rule. Simple rules
- // that cost little to run use fewer WCUs than more complex rules that use more
- // processing power. Rule group capacity is fixed at creation, which helps users
- // plan their web ACL WCU usage when they use a rule group. The WCU limit for
- // web ACLs is 1,500.
- //
- // Capacity is a required field
- Capacity *int64 `min:"1" type:"long" required:"true"`
- // The labels that one or more rules in this rule group match against in label
- // match statements. These labels are defined in a LabelMatchStatement specification,
- // in the Statement definition of a rule.
- ConsumedLabels []*LabelSummary `type:"list"`
- // A map of custom response keys and content bodies. When you create a rule
- // with a block action, you can send a custom response to the web request. You
- // define these for the rule group, and then use them in the rules that you
- // define in the rule group.
- //
- // For information about customizing web requests and responses, see Customizing
- // web requests and responses in WAF (https://docs.aws.amazon.com/waf/latest/developerguide/waf-custom-request-response.html)
- // in the WAF Developer Guide (https://docs.aws.amazon.com/waf/latest/developerguide/waf-chapter.html).
- //
- // For information about the limits on count and size for custom request and
- // response settings, see WAF quotas (https://docs.aws.amazon.com/waf/latest/developerguide/limits.html)
- // in the WAF Developer Guide (https://docs.aws.amazon.com/waf/latest/developerguide/waf-chapter.html).
- CustomResponseBodies map[string]*CustomResponseBody `min:"1" type:"map"`
- // A description of the rule group that helps with identification.
- Description *string `min:"1" type:"string"`
- // A unique identifier for the rule group. This ID is returned in the responses
- // to create and list commands. You provide it to operations like update and
- // delete.
- //
- // Id is a required field
- Id *string `min:"1" type:"string" required:"true"`
- // The label namespace prefix for this rule group. All labels added by rules
- // in this rule group have this prefix.
- //
- // * The syntax for the label namespace prefix for your rule groups is the
- // following: awswaf:<account ID>:rulegroup:<rule group name>:
- //
- // * When a rule with a label matches a web request, WAF adds the fully qualified
- // label to the request. A fully qualified label is made up of the label
- // namespace from the rule group or web ACL where the rule is defined and
- // the label from the rule, separated by a colon: <label namespace>:<label
- // from rule>
- LabelNamespace *string `min:"1" type:"string"`
- // The name of the rule group. You cannot change the name of a rule group after
- // you create it.
- //
- // Name is a required field
- Name *string `min:"1" type:"string" required:"true"`
- // The Rule statements used to identify the web requests that you want to allow,
- // block, or count. Each rule includes one top-level statement that WAF uses
- // to identify matching web requests, and parameters that govern how WAF handles
- // them.
- Rules []*Rule `type:"list"`
- // Defines and enables Amazon CloudWatch metrics and web request sample collection.
- //
- // VisibilityConfig is a required field
- VisibilityConfig *VisibilityConfig `type:"structure" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s RuleGroup) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s RuleGroup) GoString() string {
- return s.String()
- }
- // SetARN sets the ARN field's value.
- func (s *RuleGroup) SetARN(v string) *RuleGroup {
- s.ARN = &v
- return s
- }
- // SetAvailableLabels sets the AvailableLabels field's value.
- func (s *RuleGroup) SetAvailableLabels(v []*LabelSummary) *RuleGroup {
- s.AvailableLabels = v
- return s
- }
- // SetCapacity sets the Capacity field's value.
- func (s *RuleGroup) SetCapacity(v int64) *RuleGroup {
- s.Capacity = &v
- return s
- }
- // SetConsumedLabels sets the ConsumedLabels field's value.
- func (s *RuleGroup) SetConsumedLabels(v []*LabelSummary) *RuleGroup {
- s.ConsumedLabels = v
- return s
- }
- // SetCustomResponseBodies sets the CustomResponseBodies field's value.
- func (s *RuleGroup) SetCustomResponseBodies(v map[string]*CustomResponseBody) *RuleGroup {
- s.CustomResponseBodies = v
- return s
- }
- // SetDescription sets the Description field's value.
- func (s *RuleGroup) SetDescription(v string) *RuleGroup {
- s.Description = &v
- return s
- }
- // SetId sets the Id field's value.
- func (s *RuleGroup) SetId(v string) *RuleGroup {
- s.Id = &v
- return s
- }
- // SetLabelNamespace sets the LabelNamespace field's value.
- func (s *RuleGroup) SetLabelNamespace(v string) *RuleGroup {
- s.LabelNamespace = &v
- return s
- }
- // SetName sets the Name field's value.
- func (s *RuleGroup) SetName(v string) *RuleGroup {
- s.Name = &v
- return s
- }
- // SetRules sets the Rules field's value.
- func (s *RuleGroup) SetRules(v []*Rule) *RuleGroup {
- s.Rules = v
- return s
- }
- // SetVisibilityConfig sets the VisibilityConfig field's value.
- func (s *RuleGroup) SetVisibilityConfig(v *VisibilityConfig) *RuleGroup {
- s.VisibilityConfig = v
- return s
- }
- // A rule statement used to run the rules that are defined in a RuleGroup. To
- // use this, create a rule group with your rules, then provide the ARN of the
- // rule group in this statement.
- //
- // You cannot nest a RuleGroupReferenceStatement, for example for use inside
- // a NotStatement or OrStatement. You can only use a rule group reference statement
- // at the top level inside a web ACL.
- type RuleGroupReferenceStatement struct {
- _ struct{} `type:"structure"`
- // The Amazon Resource Name (ARN) of the entity.
- //
- // ARN is a required field
- ARN *string `min:"20" type:"string" required:"true"`
- // Rules in the referenced rule group whose actions are set to Count.
- //
- // Instead of this option, use RuleActionOverrides. It accepts any valid action
- // setting, including Count.
- ExcludedRules []*ExcludedRule `type:"list"`
- // Action settings to use in the place of the rule actions that are configured
- // inside the rule group. You specify one override for each rule whose action
- // you want to change.
- //
- // You can use overrides for testing, for example you can override all of rule
- // actions to Count and then monitor the resulting count metrics to understand
- // how the rule group would handle your web traffic. You can also permanently
- // override some or all actions, to modify how the rule group manages your web
- // traffic.
- RuleActionOverrides []*RuleActionOverride `min:"1" type:"list"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s RuleGroupReferenceStatement) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s RuleGroupReferenceStatement) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *RuleGroupReferenceStatement) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "RuleGroupReferenceStatement"}
- if s.ARN == nil {
- invalidParams.Add(request.NewErrParamRequired("ARN"))
- }
- if s.ARN != nil && len(*s.ARN) < 20 {
- invalidParams.Add(request.NewErrParamMinLen("ARN", 20))
- }
- if s.RuleActionOverrides != nil && len(s.RuleActionOverrides) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("RuleActionOverrides", 1))
- }
- if s.ExcludedRules != nil {
- for i, v := range s.ExcludedRules {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "ExcludedRules", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if s.RuleActionOverrides != nil {
- for i, v := range s.RuleActionOverrides {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "RuleActionOverrides", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetARN sets the ARN field's value.
- func (s *RuleGroupReferenceStatement) SetARN(v string) *RuleGroupReferenceStatement {
- s.ARN = &v
- return s
- }
- // SetExcludedRules sets the ExcludedRules field's value.
- func (s *RuleGroupReferenceStatement) SetExcludedRules(v []*ExcludedRule) *RuleGroupReferenceStatement {
- s.ExcludedRules = v
- return s
- }
- // SetRuleActionOverrides sets the RuleActionOverrides field's value.
- func (s *RuleGroupReferenceStatement) SetRuleActionOverrides(v []*RuleActionOverride) *RuleGroupReferenceStatement {
- s.RuleActionOverrides = v
- return s
- }
- // High-level information about a RuleGroup, returned by operations like create
- // and list. This provides information like the ID, that you can use to retrieve
- // and manage a RuleGroup, and the ARN, that you provide to the RuleGroupReferenceStatement
- // to use the rule group in a Rule.
- type RuleGroupSummary struct {
- _ struct{} `type:"structure"`
- // The Amazon Resource Name (ARN) of the entity.
- ARN *string `min:"20" type:"string"`
- // A description of the rule group that helps with identification.
- Description *string `min:"1" type:"string"`
- // A unique identifier for the rule group. This ID is returned in the responses
- // to create and list commands. You provide it to operations like update and
- // delete.
- Id *string `min:"1" type:"string"`
- // A token used for optimistic locking. WAF returns a token to your get and
- // list requests, to mark the state of the entity at the time of the request.
- // To make changes to the entity associated with the token, you provide the
- // token to operations like update and delete. WAF uses the token to ensure
- // that no changes have been made to the entity since you last retrieved it.
- // If a change has been made, the update fails with a WAFOptimisticLockException.
- // If this happens, perform another get, and use the new token returned by that
- // operation.
- LockToken *string `min:"1" type:"string"`
- // The name of the data type instance. You cannot change the name after you
- // create the instance.
- Name *string `min:"1" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s RuleGroupSummary) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s RuleGroupSummary) GoString() string {
- return s.String()
- }
- // SetARN sets the ARN field's value.
- func (s *RuleGroupSummary) SetARN(v string) *RuleGroupSummary {
- s.ARN = &v
- return s
- }
- // SetDescription sets the Description field's value.
- func (s *RuleGroupSummary) SetDescription(v string) *RuleGroupSummary {
- s.Description = &v
- return s
- }
- // SetId sets the Id field's value.
- func (s *RuleGroupSummary) SetId(v string) *RuleGroupSummary {
- s.Id = &v
- return s
- }
- // SetLockToken sets the LockToken field's value.
- func (s *RuleGroupSummary) SetLockToken(v string) *RuleGroupSummary {
- s.LockToken = &v
- return s
- }
- // SetName sets the Name field's value.
- func (s *RuleGroupSummary) SetName(v string) *RuleGroupSummary {
- s.Name = &v
- return s
- }
- // High-level information about a Rule, returned by operations like DescribeManagedRuleGroup.
- // This provides information like the ID, that you can use to retrieve and manage
- // a RuleGroup, and the ARN, that you provide to the RuleGroupReferenceStatement
- // to use the rule group in a Rule.
- type RuleSummary struct {
- _ struct{} `type:"structure"`
- // The action that WAF should take on a web request when it matches a rule's
- // statement. Settings at the web ACL level can override the rule action setting.
- Action *RuleAction `type:"structure"`
- // The name of the rule.
- Name *string `min:"1" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s RuleSummary) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s RuleSummary) GoString() string {
- return s.String()
- }
- // SetAction sets the Action field's value.
- func (s *RuleSummary) SetAction(v *RuleAction) *RuleSummary {
- s.Action = v
- return s
- }
- // SetName sets the Name field's value.
- func (s *RuleSummary) SetName(v string) *RuleSummary {
- s.Name = &v
- return s
- }
- // Represents a single sampled web request. The response from GetSampledRequests
- // includes a SampledHTTPRequests complex type that appears as SampledRequests
- // in the response syntax. SampledHTTPRequests contains an array of SampledHTTPRequest
- // objects.
- type SampledHTTPRequest struct {
- _ struct{} `type:"structure"`
- // The action that WAF applied to the request.
- Action *string `type:"string"`
- // The CAPTCHA response for the request.
- CaptchaResponse *CaptchaResponse `type:"structure"`
- // The Challenge response for the request.
- ChallengeResponse *ChallengeResponse `type:"structure"`
- // Labels applied to the web request by matching rules. WAF applies fully qualified
- // labels to matching web requests. A fully qualified label is the concatenation
- // of a label namespace and a rule label. The rule's rule group or web ACL defines
- // the label namespace.
- //
- // For example, awswaf:111122223333:myRuleGroup:testRules:testNS1:testNS2:labelNameA
- // or awswaf:managed:aws:managed-rule-set:header:encoding:utf8.
- Labels []*Label `type:"list"`
- // Used only for rule group rules that have a rule action override in place
- // in the web ACL. This is the action that the rule group rule is configured
- // for, and not the action that was applied to the request. The action that
- // WAF applied is the Action value.
- OverriddenAction *string `type:"string"`
- // A complex type that contains detailed information about the request.
- //
- // Request is a required field
- Request *HTTPRequest `type:"structure" required:"true"`
- // Custom request headers inserted by WAF into the request, according to the
- // custom request configuration for the matching rule action.
- RequestHeadersInserted []*HTTPHeader `type:"list"`
- // The response code that was sent for the request.
- ResponseCodeSent *int64 `min:"200" type:"integer"`
- // The name of the Rule that the request matched. For managed rule groups, the
- // format for this name is <vendor name>#<managed rule group name>#<rule name>.
- // For your own rule groups, the format for this name is <rule group name>#<rule
- // name>. If the rule is not in a rule group, this field is absent.
- RuleNameWithinRuleGroup *string `min:"1" type:"string"`
- // The time at which WAF received the request from your Amazon Web Services
- // resource, in Unix time format (in seconds).
- Timestamp *time.Time `type:"timestamp"`
- // A value that indicates how one result in the response relates proportionally
- // to other results in the response. For example, a result that has a weight
- // of 2 represents roughly twice as many web requests as a result that has a
- // weight of 1.
- //
- // Weight is a required field
- Weight *int64 `type:"long" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s SampledHTTPRequest) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s SampledHTTPRequest) GoString() string {
- return s.String()
- }
- // SetAction sets the Action field's value.
- func (s *SampledHTTPRequest) SetAction(v string) *SampledHTTPRequest {
- s.Action = &v
- return s
- }
- // SetCaptchaResponse sets the CaptchaResponse field's value.
- func (s *SampledHTTPRequest) SetCaptchaResponse(v *CaptchaResponse) *SampledHTTPRequest {
- s.CaptchaResponse = v
- return s
- }
- // SetChallengeResponse sets the ChallengeResponse field's value.
- func (s *SampledHTTPRequest) SetChallengeResponse(v *ChallengeResponse) *SampledHTTPRequest {
- s.ChallengeResponse = v
- return s
- }
- // SetLabels sets the Labels field's value.
- func (s *SampledHTTPRequest) SetLabels(v []*Label) *SampledHTTPRequest {
- s.Labels = v
- return s
- }
- // SetOverriddenAction sets the OverriddenAction field's value.
- func (s *SampledHTTPRequest) SetOverriddenAction(v string) *SampledHTTPRequest {
- s.OverriddenAction = &v
- return s
- }
- // SetRequest sets the Request field's value.
- func (s *SampledHTTPRequest) SetRequest(v *HTTPRequest) *SampledHTTPRequest {
- s.Request = v
- return s
- }
- // SetRequestHeadersInserted sets the RequestHeadersInserted field's value.
- func (s *SampledHTTPRequest) SetRequestHeadersInserted(v []*HTTPHeader) *SampledHTTPRequest {
- s.RequestHeadersInserted = v
- return s
- }
- // SetResponseCodeSent sets the ResponseCodeSent field's value.
- func (s *SampledHTTPRequest) SetResponseCodeSent(v int64) *SampledHTTPRequest {
- s.ResponseCodeSent = &v
- return s
- }
- // SetRuleNameWithinRuleGroup sets the RuleNameWithinRuleGroup field's value.
- func (s *SampledHTTPRequest) SetRuleNameWithinRuleGroup(v string) *SampledHTTPRequest {
- s.RuleNameWithinRuleGroup = &v
- return s
- }
- // SetTimestamp sets the Timestamp field's value.
- func (s *SampledHTTPRequest) SetTimestamp(v time.Time) *SampledHTTPRequest {
- s.Timestamp = &v
- return s
- }
- // SetWeight sets the Weight field's value.
- func (s *SampledHTTPRequest) SetWeight(v int64) *SampledHTTPRequest {
- s.Weight = &v
- return s
- }
- // Inspect one of the headers in the web request, identified by name, for example,
- // User-Agent or Referer. The name isn't case sensitive.
- //
- // You can filter and inspect all headers with the FieldToMatch setting Headers.
- //
- // This is used to indicate the web request component to inspect, in the FieldToMatch
- // specification.
- //
- // Example JSON: "SingleHeader": { "Name": "haystack" }
- type SingleHeader struct {
- _ struct{} `type:"structure"`
- // The name of the query header to inspect.
- //
- // Name is a required field
- Name *string `min:"1" type:"string" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s SingleHeader) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s SingleHeader) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *SingleHeader) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "SingleHeader"}
- if s.Name == nil {
- invalidParams.Add(request.NewErrParamRequired("Name"))
- }
- if s.Name != nil && len(*s.Name) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Name", 1))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetName sets the Name field's value.
- func (s *SingleHeader) SetName(v string) *SingleHeader {
- s.Name = &v
- return s
- }
- // Inspect one query argument in the web request, identified by name, for example
- // UserName or SalesRegion. The name isn't case sensitive.
- //
- // This is used to indicate the web request component to inspect, in the FieldToMatch
- // specification.
- //
- // Example JSON: "SingleQueryArgument": { "Name": "myArgument" }
- type SingleQueryArgument struct {
- _ struct{} `type:"structure"`
- // The name of the query argument to inspect.
- //
- // Name is a required field
- Name *string `min:"1" type:"string" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s SingleQueryArgument) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s SingleQueryArgument) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *SingleQueryArgument) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "SingleQueryArgument"}
- if s.Name == nil {
- invalidParams.Add(request.NewErrParamRequired("Name"))
- }
- if s.Name != nil && len(*s.Name) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Name", 1))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetName sets the Name field's value.
- func (s *SingleQueryArgument) SetName(v string) *SingleQueryArgument {
- s.Name = &v
- return s
- }
- // A rule statement that compares a number of bytes against the size of a request
- // component, using a comparison operator, such as greater than (>) or less
- // than (<). For example, you can use a size constraint statement to look for
- // query strings that are longer than 100 bytes.
- //
- // If you configure WAF to inspect the request body, WAF inspects only the first
- // 8192 bytes (8 KB). If the request body for your web requests never exceeds
- // 8192 bytes, you could use a size constraint statement to block requests that
- // have a request body greater than 8192 bytes.
- //
- // If you choose URI for the value of Part of the request to filter on, the
- // slash (/) in the URI counts as one character. For example, the URI /logo.jpg
- // is nine characters long.
- type SizeConstraintStatement struct {
- _ struct{} `type:"structure"`
- // The operator to use to compare the request part to the size setting.
- //
- // ComparisonOperator is a required field
- ComparisonOperator *string `type:"string" required:"true" enum:"ComparisonOperator"`
- // The part of the web request that you want WAF to inspect.
- //
- // FieldToMatch is a required field
- FieldToMatch *FieldToMatch `type:"structure" required:"true"`
- // The size, in byte, to compare to the request part, after any transformations.
- //
- // Size is a required field
- Size *int64 `type:"long" required:"true"`
- // Text transformations eliminate some of the unusual formatting that attackers
- // use in web requests in an effort to bypass detection. If you specify one
- // or more transformations in a rule statement, WAF performs all transformations
- // on the content of the request component identified by FieldToMatch, starting
- // from the lowest priority setting, before inspecting the content for a match.
- //
- // TextTransformations is a required field
- TextTransformations []*TextTransformation `min:"1" type:"list" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s SizeConstraintStatement) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s SizeConstraintStatement) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *SizeConstraintStatement) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "SizeConstraintStatement"}
- if s.ComparisonOperator == nil {
- invalidParams.Add(request.NewErrParamRequired("ComparisonOperator"))
- }
- if s.FieldToMatch == nil {
- invalidParams.Add(request.NewErrParamRequired("FieldToMatch"))
- }
- if s.Size == nil {
- invalidParams.Add(request.NewErrParamRequired("Size"))
- }
- if s.TextTransformations == nil {
- invalidParams.Add(request.NewErrParamRequired("TextTransformations"))
- }
- if s.TextTransformations != nil && len(s.TextTransformations) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("TextTransformations", 1))
- }
- if s.FieldToMatch != nil {
- if err := s.FieldToMatch.Validate(); err != nil {
- invalidParams.AddNested("FieldToMatch", err.(request.ErrInvalidParams))
- }
- }
- if s.TextTransformations != nil {
- for i, v := range s.TextTransformations {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "TextTransformations", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetComparisonOperator sets the ComparisonOperator field's value.
- func (s *SizeConstraintStatement) SetComparisonOperator(v string) *SizeConstraintStatement {
- s.ComparisonOperator = &v
- return s
- }
- // SetFieldToMatch sets the FieldToMatch field's value.
- func (s *SizeConstraintStatement) SetFieldToMatch(v *FieldToMatch) *SizeConstraintStatement {
- s.FieldToMatch = v
- return s
- }
- // SetSize sets the Size field's value.
- func (s *SizeConstraintStatement) SetSize(v int64) *SizeConstraintStatement {
- s.Size = &v
- return s
- }
- // SetTextTransformations sets the TextTransformations field's value.
- func (s *SizeConstraintStatement) SetTextTransformations(v []*TextTransformation) *SizeConstraintStatement {
- s.TextTransformations = v
- return s
- }
- // A rule statement that inspects for malicious SQL code. Attackers insert malicious
- // SQL code into web requests to do things like modify your database or extract
- // data from it.
- type SqliMatchStatement struct {
- _ struct{} `type:"structure"`
- // The part of the web request that you want WAF to inspect.
- //
- // FieldToMatch is a required field
- FieldToMatch *FieldToMatch `type:"structure" required:"true"`
- // The sensitivity that you want WAF to use to inspect for SQL injection attacks.
- //
- // HIGH detects more attacks, but might generate more false positives, especially
- // if your web requests frequently contain unusual strings. For information
- // about identifying and mitigating false positives, see Testing and tuning
- // (https://docs.aws.amazon.com/waf/latest/developerguide/web-acl-testing.html)
- // in the WAF Developer Guide.
- //
- // LOW is generally a better choice for resources that already have other protections
- // against SQL injection attacks or that have a low tolerance for false positives.
- //
- // Default: LOW
- SensitivityLevel *string `type:"string" enum:"SensitivityLevel"`
- // Text transformations eliminate some of the unusual formatting that attackers
- // use in web requests in an effort to bypass detection. If you specify one
- // or more transformations in a rule statement, WAF performs all transformations
- // on the content of the request component identified by FieldToMatch, starting
- // from the lowest priority setting, before inspecting the content for a match.
- //
- // TextTransformations is a required field
- TextTransformations []*TextTransformation `min:"1" type:"list" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s SqliMatchStatement) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s SqliMatchStatement) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *SqliMatchStatement) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "SqliMatchStatement"}
- if s.FieldToMatch == nil {
- invalidParams.Add(request.NewErrParamRequired("FieldToMatch"))
- }
- if s.TextTransformations == nil {
- invalidParams.Add(request.NewErrParamRequired("TextTransformations"))
- }
- if s.TextTransformations != nil && len(s.TextTransformations) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("TextTransformations", 1))
- }
- if s.FieldToMatch != nil {
- if err := s.FieldToMatch.Validate(); err != nil {
- invalidParams.AddNested("FieldToMatch", err.(request.ErrInvalidParams))
- }
- }
- if s.TextTransformations != nil {
- for i, v := range s.TextTransformations {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "TextTransformations", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetFieldToMatch sets the FieldToMatch field's value.
- func (s *SqliMatchStatement) SetFieldToMatch(v *FieldToMatch) *SqliMatchStatement {
- s.FieldToMatch = v
- return s
- }
- // SetSensitivityLevel sets the SensitivityLevel field's value.
- func (s *SqliMatchStatement) SetSensitivityLevel(v string) *SqliMatchStatement {
- s.SensitivityLevel = &v
- return s
- }
- // SetTextTransformations sets the TextTransformations field's value.
- func (s *SqliMatchStatement) SetTextTransformations(v []*TextTransformation) *SqliMatchStatement {
- s.TextTransformations = v
- return s
- }
- // The processing guidance for a Rule, used by WAF to determine whether a web
- // request matches the rule.
- //
- // For example specifications, see the examples section of CreateWebACL.
- type Statement struct {
- _ struct{} `type:"structure"`
- // A logical rule statement used to combine other rule statements with AND logic.
- // You provide more than one Statement within the AndStatement.
- AndStatement *AndStatement `type:"structure"`
- // A rule statement that defines a string match search for WAF to apply to web
- // requests. The byte match statement provides the bytes to search for, the
- // location in requests that you want WAF to search, and other settings. The
- // bytes to search for are typically a string that corresponds with ASCII characters.
- // In the WAF console and the developer guide, this is called a string match
- // statement.
- ByteMatchStatement *ByteMatchStatement `type:"structure"`
- // A rule statement that labels web requests by country and region and that
- // matches against web requests based on country code. A geo match rule labels
- // every request that it inspects regardless of whether it finds a match.
- //
- // * To manage requests only by country, you can use this statement by itself
- // and specify the countries that you want to match against in the CountryCodes
- // array.
- //
- // * Otherwise, configure your geo match rule with Count action so that it
- // only labels requests. Then, add one or more label match rules to run after
- // the geo match rule and configure them to match against the geographic
- // labels and handle the requests as needed.
- //
- // WAF labels requests using the alpha-2 country and region codes from the International
- // Organization for Standardization (ISO) 3166 standard. WAF determines the
- // codes using either the IP address in the web request origin or, if you specify
- // it, the address in the geo match ForwardedIPConfig.
- //
- // If you use the web request origin, the label formats are awswaf:clientip:geo:region:<ISO
- // country code>-<ISO region code> and awswaf:clientip:geo:country:<ISO country
- // code>.
- //
- // If you use a forwarded IP address, the label formats are awswaf:forwardedip:geo:region:<ISO
- // country code>-<ISO region code> and awswaf:forwardedip:geo:country:<ISO country
- // code>.
- //
- // For additional details, see Geographic match rule statement (https://docs.aws.amazon.com/waf/latest/developerguide/waf-rule-statement-type-geo-match.html)
- // in the WAF Developer Guide (https://docs.aws.amazon.com/waf/latest/developerguide/waf-chapter.html).
- GeoMatchStatement *GeoMatchStatement `type:"structure"`
- // A rule statement used to detect web requests coming from particular IP addresses
- // or address ranges. To use this, create an IPSet that specifies the addresses
- // you want to detect, then use the ARN of that set in this statement. To create
- // an IP set, see CreateIPSet.
- //
- // Each IP set rule statement references an IP set. You create and maintain
- // the set independent of your rules. This allows you to use the single set
- // in multiple rules. When you update the referenced set, WAF automatically
- // updates all rules that reference it.
- IPSetReferenceStatement *IPSetReferenceStatement `type:"structure"`
- // A rule statement to match against labels that have been added to the web
- // request by rules that have already run in the web ACL.
- //
- // The label match statement provides the label or namespace string to search
- // for. The label string can represent a part or all of the fully qualified
- // label name that had been added to the web request. Fully qualified labels
- // have a prefix, optional namespaces, and label name. The prefix identifies
- // the rule group or web ACL context of the rule that added the label. If you
- // do not provide the fully qualified name in your label match string, WAF performs
- // the search for labels that were added in the same context as the label match
- // statement.
- LabelMatchStatement *LabelMatchStatement `type:"structure"`
- // A rule statement used to run the rules that are defined in a managed rule
- // group. To use this, provide the vendor name and the name of the rule group
- // in this statement. You can retrieve the required names by calling ListAvailableManagedRuleGroups.
- //
- // You cannot nest a ManagedRuleGroupStatement, for example for use inside a
- // NotStatement or OrStatement. It can only be referenced as a top-level statement
- // within a rule.
- //
- // You are charged additional fees when you use the WAF Bot Control managed
- // rule group AWSManagedRulesBotControlRuleSet or the WAF Fraud Control account
- // takeover prevention (ATP) managed rule group AWSManagedRulesATPRuleSet. For
- // more information, see WAF Pricing (http://aws.amazon.com/waf/pricing/).
- ManagedRuleGroupStatement *ManagedRuleGroupStatement `type:"structure"`
- // A logical rule statement used to negate the results of another rule statement.
- // You provide one Statement within the NotStatement.
- NotStatement *NotStatement `type:"structure"`
- // A logical rule statement used to combine other rule statements with OR logic.
- // You provide more than one Statement within the OrStatement.
- OrStatement *OrStatement `type:"structure"`
- // A rate-based rule tracks the rate of requests for each originating IP address,
- // and triggers the rule action when the rate exceeds a limit that you specify
- // on the number of requests in any 5-minute time span. You can use this to
- // put a temporary block on requests from an IP address that is sending excessive
- // requests.
- //
- // WAF tracks and manages web requests separately for each instance of a rate-based
- // rule that you use. For example, if you provide the same rate-based rule settings
- // in two web ACLs, each of the two rule statements represents a separate instance
- // of the rate-based rule and gets its own tracking and management by WAF. If
- // you define a rate-based rule inside a rule group, and then use that rule
- // group in multiple places, each use creates a separate instance of the rate-based
- // rule that gets its own tracking and management by WAF.
- //
- // When the rule action triggers, WAF blocks additional requests from the IP
- // address until the request rate falls below the limit.
- //
- // You can optionally nest another statement inside the rate-based statement,
- // to narrow the scope of the rule so that it only counts requests that match
- // the nested statement. For example, based on recent requests that you have
- // seen from an attacker, you might create a rate-based rule with a nested AND
- // rule statement that contains the following nested statements:
- //
- // * An IP match statement with an IP set that specified the address 192.0.2.44.
- //
- // * A string match statement that searches in the User-Agent header for
- // the string BadBot.
- //
- // In this rate-based rule, you also define a rate limit. For this example,
- // the rate limit is 1,000. Requests that meet the criteria of both of the nested
- // statements are counted. If the count exceeds 1,000 requests per five minutes,
- // the rule action triggers. Requests that do not meet the criteria of both
- // of the nested statements are not counted towards the rate limit and are not
- // affected by this rule.
- //
- // You cannot nest a RateBasedStatement inside another statement, for example
- // inside a NotStatement or OrStatement. You can define a RateBasedStatement
- // inside a web ACL and inside a rule group.
- RateBasedStatement *RateBasedStatement `type:"structure"`
- // A rule statement used to search web request components for a match against
- // a single regular expression.
- RegexMatchStatement *RegexMatchStatement `type:"structure"`
- // A rule statement used to search web request components for matches with regular
- // expressions. To use this, create a RegexPatternSet that specifies the expressions
- // that you want to detect, then use the ARN of that set in this statement.
- // A web request matches the pattern set rule statement if the request component
- // matches any of the patterns in the set. To create a regex pattern set, see
- // CreateRegexPatternSet.
- //
- // Each regex pattern set rule statement references a regex pattern set. You
- // create and maintain the set independent of your rules. This allows you to
- // use the single set in multiple rules. When you update the referenced set,
- // WAF automatically updates all rules that reference it.
- RegexPatternSetReferenceStatement *RegexPatternSetReferenceStatement `type:"structure"`
- // A rule statement used to run the rules that are defined in a RuleGroup. To
- // use this, create a rule group with your rules, then provide the ARN of the
- // rule group in this statement.
- //
- // You cannot nest a RuleGroupReferenceStatement, for example for use inside
- // a NotStatement or OrStatement. You can only use a rule group reference statement
- // at the top level inside a web ACL.
- RuleGroupReferenceStatement *RuleGroupReferenceStatement `type:"structure"`
- // A rule statement that compares a number of bytes against the size of a request
- // component, using a comparison operator, such as greater than (>) or less
- // than (<). For example, you can use a size constraint statement to look for
- // query strings that are longer than 100 bytes.
- //
- // If you configure WAF to inspect the request body, WAF inspects only the first
- // 8192 bytes (8 KB). If the request body for your web requests never exceeds
- // 8192 bytes, you could use a size constraint statement to block requests that
- // have a request body greater than 8192 bytes.
- //
- // If you choose URI for the value of Part of the request to filter on, the
- // slash (/) in the URI counts as one character. For example, the URI /logo.jpg
- // is nine characters long.
- SizeConstraintStatement *SizeConstraintStatement `type:"structure"`
- // A rule statement that inspects for malicious SQL code. Attackers insert malicious
- // SQL code into web requests to do things like modify your database or extract
- // data from it.
- SqliMatchStatement *SqliMatchStatement `type:"structure"`
- // A rule statement that inspects for cross-site scripting (XSS) attacks. In
- // XSS attacks, the attacker uses vulnerabilities in a benign website as a vehicle
- // to inject malicious client-site scripts into other legitimate web browsers.
- XssMatchStatement *XssMatchStatement `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s Statement) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s Statement) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *Statement) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "Statement"}
- if s.AndStatement != nil {
- if err := s.AndStatement.Validate(); err != nil {
- invalidParams.AddNested("AndStatement", err.(request.ErrInvalidParams))
- }
- }
- if s.ByteMatchStatement != nil {
- if err := s.ByteMatchStatement.Validate(); err != nil {
- invalidParams.AddNested("ByteMatchStatement", err.(request.ErrInvalidParams))
- }
- }
- if s.GeoMatchStatement != nil {
- if err := s.GeoMatchStatement.Validate(); err != nil {
- invalidParams.AddNested("GeoMatchStatement", err.(request.ErrInvalidParams))
- }
- }
- if s.IPSetReferenceStatement != nil {
- if err := s.IPSetReferenceStatement.Validate(); err != nil {
- invalidParams.AddNested("IPSetReferenceStatement", err.(request.ErrInvalidParams))
- }
- }
- if s.LabelMatchStatement != nil {
- if err := s.LabelMatchStatement.Validate(); err != nil {
- invalidParams.AddNested("LabelMatchStatement", err.(request.ErrInvalidParams))
- }
- }
- if s.ManagedRuleGroupStatement != nil {
- if err := s.ManagedRuleGroupStatement.Validate(); err != nil {
- invalidParams.AddNested("ManagedRuleGroupStatement", err.(request.ErrInvalidParams))
- }
- }
- if s.NotStatement != nil {
- if err := s.NotStatement.Validate(); err != nil {
- invalidParams.AddNested("NotStatement", err.(request.ErrInvalidParams))
- }
- }
- if s.OrStatement != nil {
- if err := s.OrStatement.Validate(); err != nil {
- invalidParams.AddNested("OrStatement", err.(request.ErrInvalidParams))
- }
- }
- if s.RateBasedStatement != nil {
- if err := s.RateBasedStatement.Validate(); err != nil {
- invalidParams.AddNested("RateBasedStatement", err.(request.ErrInvalidParams))
- }
- }
- if s.RegexMatchStatement != nil {
- if err := s.RegexMatchStatement.Validate(); err != nil {
- invalidParams.AddNested("RegexMatchStatement", err.(request.ErrInvalidParams))
- }
- }
- if s.RegexPatternSetReferenceStatement != nil {
- if err := s.RegexPatternSetReferenceStatement.Validate(); err != nil {
- invalidParams.AddNested("RegexPatternSetReferenceStatement", err.(request.ErrInvalidParams))
- }
- }
- if s.RuleGroupReferenceStatement != nil {
- if err := s.RuleGroupReferenceStatement.Validate(); err != nil {
- invalidParams.AddNested("RuleGroupReferenceStatement", err.(request.ErrInvalidParams))
- }
- }
- if s.SizeConstraintStatement != nil {
- if err := s.SizeConstraintStatement.Validate(); err != nil {
- invalidParams.AddNested("SizeConstraintStatement", err.(request.ErrInvalidParams))
- }
- }
- if s.SqliMatchStatement != nil {
- if err := s.SqliMatchStatement.Validate(); err != nil {
- invalidParams.AddNested("SqliMatchStatement", err.(request.ErrInvalidParams))
- }
- }
- if s.XssMatchStatement != nil {
- if err := s.XssMatchStatement.Validate(); err != nil {
- invalidParams.AddNested("XssMatchStatement", err.(request.ErrInvalidParams))
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetAndStatement sets the AndStatement field's value.
- func (s *Statement) SetAndStatement(v *AndStatement) *Statement {
- s.AndStatement = v
- return s
- }
- // SetByteMatchStatement sets the ByteMatchStatement field's value.
- func (s *Statement) SetByteMatchStatement(v *ByteMatchStatement) *Statement {
- s.ByteMatchStatement = v
- return s
- }
- // SetGeoMatchStatement sets the GeoMatchStatement field's value.
- func (s *Statement) SetGeoMatchStatement(v *GeoMatchStatement) *Statement {
- s.GeoMatchStatement = v
- return s
- }
- // SetIPSetReferenceStatement sets the IPSetReferenceStatement field's value.
- func (s *Statement) SetIPSetReferenceStatement(v *IPSetReferenceStatement) *Statement {
- s.IPSetReferenceStatement = v
- return s
- }
- // SetLabelMatchStatement sets the LabelMatchStatement field's value.
- func (s *Statement) SetLabelMatchStatement(v *LabelMatchStatement) *Statement {
- s.LabelMatchStatement = v
- return s
- }
- // SetManagedRuleGroupStatement sets the ManagedRuleGroupStatement field's value.
- func (s *Statement) SetManagedRuleGroupStatement(v *ManagedRuleGroupStatement) *Statement {
- s.ManagedRuleGroupStatement = v
- return s
- }
- // SetNotStatement sets the NotStatement field's value.
- func (s *Statement) SetNotStatement(v *NotStatement) *Statement {
- s.NotStatement = v
- return s
- }
- // SetOrStatement sets the OrStatement field's value.
- func (s *Statement) SetOrStatement(v *OrStatement) *Statement {
- s.OrStatement = v
- return s
- }
- // SetRateBasedStatement sets the RateBasedStatement field's value.
- func (s *Statement) SetRateBasedStatement(v *RateBasedStatement) *Statement {
- s.RateBasedStatement = v
- return s
- }
- // SetRegexMatchStatement sets the RegexMatchStatement field's value.
- func (s *Statement) SetRegexMatchStatement(v *RegexMatchStatement) *Statement {
- s.RegexMatchStatement = v
- return s
- }
- // SetRegexPatternSetReferenceStatement sets the RegexPatternSetReferenceStatement field's value.
- func (s *Statement) SetRegexPatternSetReferenceStatement(v *RegexPatternSetReferenceStatement) *Statement {
- s.RegexPatternSetReferenceStatement = v
- return s
- }
- // SetRuleGroupReferenceStatement sets the RuleGroupReferenceStatement field's value.
- func (s *Statement) SetRuleGroupReferenceStatement(v *RuleGroupReferenceStatement) *Statement {
- s.RuleGroupReferenceStatement = v
- return s
- }
- // SetSizeConstraintStatement sets the SizeConstraintStatement field's value.
- func (s *Statement) SetSizeConstraintStatement(v *SizeConstraintStatement) *Statement {
- s.SizeConstraintStatement = v
- return s
- }
- // SetSqliMatchStatement sets the SqliMatchStatement field's value.
- func (s *Statement) SetSqliMatchStatement(v *SqliMatchStatement) *Statement {
- s.SqliMatchStatement = v
- return s
- }
- // SetXssMatchStatement sets the XssMatchStatement field's value.
- func (s *Statement) SetXssMatchStatement(v *XssMatchStatement) *Statement {
- s.XssMatchStatement = v
- return s
- }
- // A tag associated with an Amazon Web Services resource. Tags are key:value
- // pairs that you can use to categorize and manage your resources, for purposes
- // like billing or other management. Typically, the tag key represents a category,
- // such as "environment", and the tag value represents a specific value within
- // that category, such as "test," "development," or "production". Or you might
- // set the tag key to "customer" and the value to the customer name or ID. You
- // can specify one or more tags to add to each Amazon Web Services resource,
- // up to 50 tags for a resource.
- //
- // You can tag the Amazon Web Services resources that you manage through WAF:
- // web ACLs, rule groups, IP sets, and regex pattern sets. You can't manage
- // or view tags through the WAF console.
- type Tag struct {
- _ struct{} `type:"structure"`
- // Part of the key:value pair that defines a tag. You can use a tag key to describe
- // a category of information, such as "customer." Tag keys are case-sensitive.
- //
- // Key is a required field
- Key *string `min:"1" type:"string" required:"true"`
- // Part of the key:value pair that defines a tag. You can use a tag value to
- // describe a specific value within a category, such as "companyA" or "companyB."
- // Tag values are case-sensitive.
- //
- // Value is a required field
- Value *string `type:"string" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s Tag) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s Tag) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *Tag) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "Tag"}
- if s.Key == nil {
- invalidParams.Add(request.NewErrParamRequired("Key"))
- }
- if s.Key != nil && len(*s.Key) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Key", 1))
- }
- if s.Value == nil {
- invalidParams.Add(request.NewErrParamRequired("Value"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetKey sets the Key field's value.
- func (s *Tag) SetKey(v string) *Tag {
- s.Key = &v
- return s
- }
- // SetValue sets the Value field's value.
- func (s *Tag) SetValue(v string) *Tag {
- s.Value = &v
- return s
- }
- // The collection of tagging definitions for an Amazon Web Services resource.
- // Tags are key:value pairs that you can use to categorize and manage your resources,
- // for purposes like billing or other management. Typically, the tag key represents
- // a category, such as "environment", and the tag value represents a specific
- // value within that category, such as "test," "development," or "production".
- // Or you might set the tag key to "customer" and the value to the customer
- // name or ID. You can specify one or more tags to add to each Amazon Web Services
- // resource, up to 50 tags for a resource.
- //
- // You can tag the Amazon Web Services resources that you manage through WAF:
- // web ACLs, rule groups, IP sets, and regex pattern sets. You can't manage
- // or view tags through the WAF console.
- type TagInfoForResource struct {
- _ struct{} `type:"structure"`
- // The Amazon Resource Name (ARN) of the resource.
- ResourceARN *string `min:"20" type:"string"`
- // The array of Tag objects defined for the resource.
- TagList []*Tag `min:"1" type:"list"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s TagInfoForResource) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s TagInfoForResource) GoString() string {
- return s.String()
- }
- // SetResourceARN sets the ResourceARN field's value.
- func (s *TagInfoForResource) SetResourceARN(v string) *TagInfoForResource {
- s.ResourceARN = &v
- return s
- }
- // SetTagList sets the TagList field's value.
- func (s *TagInfoForResource) SetTagList(v []*Tag) *TagInfoForResource {
- s.TagList = v
- return s
- }
- type TagResourceInput struct {
- _ struct{} `type:"structure"`
- // The Amazon Resource Name (ARN) of the resource.
- //
- // ResourceARN is a required field
- ResourceARN *string `min:"20" type:"string" required:"true"`
- // An array of key:value pairs to associate with the resource.
- //
- // Tags is a required field
- Tags []*Tag `min:"1" type:"list" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s TagResourceInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s TagResourceInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *TagResourceInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "TagResourceInput"}
- if s.ResourceARN == nil {
- invalidParams.Add(request.NewErrParamRequired("ResourceARN"))
- }
- if s.ResourceARN != nil && len(*s.ResourceARN) < 20 {
- invalidParams.Add(request.NewErrParamMinLen("ResourceARN", 20))
- }
- if s.Tags == nil {
- invalidParams.Add(request.NewErrParamRequired("Tags"))
- }
- if s.Tags != nil && len(s.Tags) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Tags", 1))
- }
- if s.Tags != nil {
- for i, v := range s.Tags {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "Tags", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetResourceARN sets the ResourceARN field's value.
- func (s *TagResourceInput) SetResourceARN(v string) *TagResourceInput {
- s.ResourceARN = &v
- return s
- }
- // SetTags sets the Tags field's value.
- func (s *TagResourceInput) SetTags(v []*Tag) *TagResourceInput {
- s.Tags = v
- return s
- }
- type TagResourceOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s TagResourceOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s TagResourceOutput) GoString() string {
- return s.String()
- }
- // Text transformations eliminate some of the unusual formatting that attackers
- // use in web requests in an effort to bypass detection.
- type TextTransformation struct {
- _ struct{} `type:"structure"`
- // Sets the relative processing order for multiple transformations that are
- // defined for a rule statement. WAF processes all transformations, from lowest
- // priority to highest, before inspecting the transformed content. The priorities
- // don't need to be consecutive, but they must all be different.
- //
- // Priority is a required field
- Priority *int64 `type:"integer" required:"true"`
- // You can specify the following transformation types:
- //
- // BASE64_DECODE - Decode a Base64-encoded string.
- //
- // BASE64_DECODE_EXT - Decode a Base64-encoded string, but use a forgiving implementation
- // that ignores characters that aren't valid.
- //
- // CMD_LINE - Command-line transformations. These are helpful in reducing effectiveness
- // of attackers who inject an operating system command-line command and use
- // unusual formatting to disguise some or all of the command.
- //
- // * Delete the following characters: \ " ' ^
- //
- // * Delete spaces before the following characters: / (
- //
- // * Replace the following characters with a space: , ;
- //
- // * Replace multiple spaces with one space
- //
- // * Convert uppercase letters (A-Z) to lowercase (a-z)
- //
- // COMPRESS_WHITE_SPACE - Replace these characters with a space character (decimal
- // 32):
- //
- // * \f, formfeed, decimal 12
- //
- // * \t, tab, decimal 9
- //
- // * \n, newline, decimal 10
- //
- // * \r, carriage return, decimal 13
- //
- // * \v, vertical tab, decimal 11
- //
- // * Non-breaking space, decimal 160
- //
- // COMPRESS_WHITE_SPACE also replaces multiple spaces with one space.
- //
- // CSS_DECODE - Decode characters that were encoded using CSS 2.x escape rules
- // syndata.html#characters. This function uses up to two bytes in the decoding
- // process, so it can help to uncover ASCII characters that were encoded using
- // CSS encoding that wouldn’t typically be encoded. It's also useful in countering
- // evasion, which is a combination of a backslash and non-hexadecimal characters.
- // For example, ja\vascript for javascript.
- //
- // ESCAPE_SEQ_DECODE - Decode the following ANSI C escape sequences: \a, \b,
- // \f, \n, \r, \t, \v, \\, \?, \', \", \xHH (hexadecimal), \0OOO (octal). Encodings
- // that aren't valid remain in the output.
- //
- // HEX_DECODE - Decode a string of hexadecimal characters into a binary.
- //
- // HTML_ENTITY_DECODE - Replace HTML-encoded characters with unencoded characters.
- // HTML_ENTITY_DECODE performs these operations:
- //
- // * Replaces (ampersand)quot; with "
- //
- // * Replaces (ampersand)nbsp; with a non-breaking space, decimal 160
- //
- // * Replaces (ampersand)lt; with a "less than" symbol
- //
- // * Replaces (ampersand)gt; with >
- //
- // * Replaces characters that are represented in hexadecimal format, (ampersand)#xhhhh;,
- // with the corresponding characters
- //
- // * Replaces characters that are represented in decimal format, (ampersand)#nnnn;,
- // with the corresponding characters
- //
- // JS_DECODE - Decode JavaScript escape sequences. If a \ u HHHH code is in
- // the full-width ASCII code range of FF01-FF5E, then the higher byte is used
- // to detect and adjust the lower byte. If not, only the lower byte is used
- // and the higher byte is zeroed, causing a possible loss of information.
- //
- // LOWERCASE - Convert uppercase letters (A-Z) to lowercase (a-z).
- //
- // MD5 - Calculate an MD5 hash from the data in the input. The computed hash
- // is in a raw binary form.
- //
- // NONE - Specify NONE if you don't want any text transformations.
- //
- // NORMALIZE_PATH - Remove multiple slashes, directory self-references, and
- // directory back-references that are not at the beginning of the input from
- // an input string.
- //
- // NORMALIZE_PATH_WIN - This is the same as NORMALIZE_PATH, but first converts
- // backslash characters to forward slashes.
- //
- // REMOVE_NULLS - Remove all NULL bytes from the input.
- //
- // REPLACE_COMMENTS - Replace each occurrence of a C-style comment (/* ... */)
- // with a single space. Multiple consecutive occurrences are not compressed.
- // Unterminated comments are also replaced with a space (ASCII 0x20). However,
- // a standalone termination of a comment (*/) is not acted upon.
- //
- // REPLACE_NULLS - Replace NULL bytes in the input with space characters (ASCII
- // 0x20).
- //
- // SQL_HEX_DECODE - Decode SQL hex data. Example (0x414243) will be decoded
- // to (ABC).
- //
- // URL_DECODE - Decode a URL-encoded value.
- //
- // URL_DECODE_UNI - Like URL_DECODE, but with support for Microsoft-specific
- // %u encoding. If the code is in the full-width ASCII code range of FF01-FF5E,
- // the higher byte is used to detect and adjust the lower byte. Otherwise, only
- // the lower byte is used and the higher byte is zeroed.
- //
- // UTF8_TO_UNICODE - Convert all UTF-8 character sequences to Unicode. This
- // helps input normalization, and minimizing false-positives and false-negatives
- // for non-English languages.
- //
- // Type is a required field
- Type *string `type:"string" required:"true" enum:"TextTransformationType"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s TextTransformation) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s TextTransformation) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *TextTransformation) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "TextTransformation"}
- if s.Priority == nil {
- invalidParams.Add(request.NewErrParamRequired("Priority"))
- }
- if s.Type == nil {
- invalidParams.Add(request.NewErrParamRequired("Type"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetPriority sets the Priority field's value.
- func (s *TextTransformation) SetPriority(v int64) *TextTransformation {
- s.Priority = &v
- return s
- }
- // SetType sets the Type field's value.
- func (s *TextTransformation) SetType(v string) *TextTransformation {
- s.Type = &v
- return s
- }
- // In a GetSampledRequests request, the StartTime and EndTime objects specify
- // the time range for which you want WAF to return a sample of web requests.
- //
- // You must specify the times in Coordinated Universal Time (UTC) format. UTC
- // format includes the special designator, Z. For example, "2016-09-27T14:50Z".
- // You can specify any time range in the previous three hours.
- //
- // In a GetSampledRequests response, the StartTime and EndTime objects specify
- // the time range for which WAF actually returned a sample of web requests.
- // WAF gets the specified number of requests from among the first 5,000 requests
- // that your Amazon Web Services resource receives during the specified time
- // period. If your resource receives more than 5,000 requests during that period,
- // WAF stops sampling after the 5,000th request. In that case, EndTime is the
- // time that WAF received the 5,000th request.
- type TimeWindow struct {
- _ struct{} `type:"structure"`
- // The end of the time range from which you want GetSampledRequests to return
- // a sample of the requests that your Amazon Web Services resource received.
- // You must specify the times in Coordinated Universal Time (UTC) format. UTC
- // format includes the special designator, Z. For example, "2016-09-27T14:50Z".
- // You can specify any time range in the previous three hours.
- //
- // EndTime is a required field
- EndTime *time.Time `type:"timestamp" required:"true"`
- // The beginning of the time range from which you want GetSampledRequests to
- // return a sample of the requests that your Amazon Web Services resource received.
- // You must specify the times in Coordinated Universal Time (UTC) format. UTC
- // format includes the special designator, Z. For example, "2016-09-27T14:50Z".
- // You can specify any time range in the previous three hours.
- //
- // StartTime is a required field
- StartTime *time.Time `type:"timestamp" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s TimeWindow) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s TimeWindow) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *TimeWindow) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "TimeWindow"}
- if s.EndTime == nil {
- invalidParams.Add(request.NewErrParamRequired("EndTime"))
- }
- if s.StartTime == nil {
- invalidParams.Add(request.NewErrParamRequired("StartTime"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetEndTime sets the EndTime field's value.
- func (s *TimeWindow) SetEndTime(v time.Time) *TimeWindow {
- s.EndTime = &v
- return s
- }
- // SetStartTime sets the StartTime field's value.
- func (s *TimeWindow) SetStartTime(v time.Time) *TimeWindow {
- s.StartTime = &v
- return s
- }
- type UntagResourceInput struct {
- _ struct{} `type:"structure"`
- // The Amazon Resource Name (ARN) of the resource.
- //
- // ResourceARN is a required field
- ResourceARN *string `min:"20" type:"string" required:"true"`
- // An array of keys identifying the tags to disassociate from the resource.
- //
- // TagKeys is a required field
- TagKeys []*string `min:"1" type:"list" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s UntagResourceInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s UntagResourceInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *UntagResourceInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "UntagResourceInput"}
- if s.ResourceARN == nil {
- invalidParams.Add(request.NewErrParamRequired("ResourceARN"))
- }
- if s.ResourceARN != nil && len(*s.ResourceARN) < 20 {
- invalidParams.Add(request.NewErrParamMinLen("ResourceARN", 20))
- }
- if s.TagKeys == nil {
- invalidParams.Add(request.NewErrParamRequired("TagKeys"))
- }
- if s.TagKeys != nil && len(s.TagKeys) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("TagKeys", 1))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetResourceARN sets the ResourceARN field's value.
- func (s *UntagResourceInput) SetResourceARN(v string) *UntagResourceInput {
- s.ResourceARN = &v
- return s
- }
- // SetTagKeys sets the TagKeys field's value.
- func (s *UntagResourceInput) SetTagKeys(v []*string) *UntagResourceInput {
- s.TagKeys = v
- return s
- }
- type UntagResourceOutput struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s UntagResourceOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s UntagResourceOutput) GoString() string {
- return s.String()
- }
- type UpdateIPSetInput struct {
- _ struct{} `type:"structure"`
- // Contains an array of strings that specifies zero or more IP addresses or
- // blocks of IP addresses. All addresses must be specified using Classless Inter-Domain
- // Routing (CIDR) notation. WAF supports all IPv4 and IPv6 CIDR ranges except
- // for /0.
- //
- // Example address strings:
- //
- // * To configure WAF to allow, block, or count requests that originated
- // from the IP address 192.0.2.44, specify 192.0.2.44/32.
- //
- // * To configure WAF to allow, block, or count requests that originated
- // from IP addresses from 192.0.2.0 to 192.0.2.255, specify 192.0.2.0/24.
- //
- // * To configure WAF to allow, block, or count requests that originated
- // from the IP address 1111:0000:0000:0000:0000:0000:0000:0111, specify 1111:0000:0000:0000:0000:0000:0000:0111/128.
- //
- // * To configure WAF to allow, block, or count requests that originated
- // from IP addresses 1111:0000:0000:0000:0000:0000:0000:0000 to 1111:0000:0000:0000:ffff:ffff:ffff:ffff,
- // specify 1111:0000:0000:0000:0000:0000:0000:0000/64.
- //
- // For more information about CIDR notation, see the Wikipedia entry Classless
- // Inter-Domain Routing (https://en.wikipedia.org/wiki/Classless_Inter-Domain_Routing).
- //
- // Example JSON Addresses specifications:
- //
- // * Empty array: "Addresses": []
- //
- // * Array with one address: "Addresses": ["192.0.2.44/32"]
- //
- // * Array with three addresses: "Addresses": ["192.0.2.44/32", "192.0.2.0/24",
- // "192.0.0.0/16"]
- //
- // * INVALID specification: "Addresses": [""] INVALID
- //
- // Addresses is a required field
- Addresses []*string `type:"list" required:"true"`
- // A description of the IP set that helps with identification.
- Description *string `min:"1" type:"string"`
- // A unique identifier for the set. This ID is returned in the responses to
- // create and list commands. You provide it to operations like update and delete.
- //
- // Id is a required field
- Id *string `min:"1" type:"string" required:"true"`
- // A token used for optimistic locking. WAF returns a token to your get and
- // list requests, to mark the state of the entity at the time of the request.
- // To make changes to the entity associated with the token, you provide the
- // token to operations like update and delete. WAF uses the token to ensure
- // that no changes have been made to the entity since you last retrieved it.
- // If a change has been made, the update fails with a WAFOptimisticLockException.
- // If this happens, perform another get, and use the new token returned by that
- // operation.
- //
- // LockToken is a required field
- LockToken *string `min:"1" type:"string" required:"true"`
- // The name of the IP set. You cannot change the name of an IPSet after you
- // create it.
- //
- // Name is a required field
- Name *string `min:"1" type:"string" required:"true"`
- // Specifies whether this is for an Amazon CloudFront distribution or for a
- // regional application. A regional application can be an Application Load Balancer
- // (ALB), an Amazon API Gateway REST API, an AppSync GraphQL API, or an Amazon
- // Cognito user pool.
- //
- // To work with CloudFront, you must also specify the Region US East (N. Virginia)
- // as follows:
- //
- // * CLI - Specify the Region when you use the CloudFront scope: --scope=CLOUDFRONT
- // --region=us-east-1.
- //
- // * API and SDKs - For all calls, use the Region endpoint us-east-1.
- //
- // Scope is a required field
- Scope *string `type:"string" required:"true" enum:"Scope"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s UpdateIPSetInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s UpdateIPSetInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *UpdateIPSetInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "UpdateIPSetInput"}
- if s.Addresses == nil {
- invalidParams.Add(request.NewErrParamRequired("Addresses"))
- }
- if s.Description != nil && len(*s.Description) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Description", 1))
- }
- if s.Id == nil {
- invalidParams.Add(request.NewErrParamRequired("Id"))
- }
- if s.Id != nil && len(*s.Id) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Id", 1))
- }
- if s.LockToken == nil {
- invalidParams.Add(request.NewErrParamRequired("LockToken"))
- }
- if s.LockToken != nil && len(*s.LockToken) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("LockToken", 1))
- }
- if s.Name == nil {
- invalidParams.Add(request.NewErrParamRequired("Name"))
- }
- if s.Name != nil && len(*s.Name) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Name", 1))
- }
- if s.Scope == nil {
- invalidParams.Add(request.NewErrParamRequired("Scope"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetAddresses sets the Addresses field's value.
- func (s *UpdateIPSetInput) SetAddresses(v []*string) *UpdateIPSetInput {
- s.Addresses = v
- return s
- }
- // SetDescription sets the Description field's value.
- func (s *UpdateIPSetInput) SetDescription(v string) *UpdateIPSetInput {
- s.Description = &v
- return s
- }
- // SetId sets the Id field's value.
- func (s *UpdateIPSetInput) SetId(v string) *UpdateIPSetInput {
- s.Id = &v
- return s
- }
- // SetLockToken sets the LockToken field's value.
- func (s *UpdateIPSetInput) SetLockToken(v string) *UpdateIPSetInput {
- s.LockToken = &v
- return s
- }
- // SetName sets the Name field's value.
- func (s *UpdateIPSetInput) SetName(v string) *UpdateIPSetInput {
- s.Name = &v
- return s
- }
- // SetScope sets the Scope field's value.
- func (s *UpdateIPSetInput) SetScope(v string) *UpdateIPSetInput {
- s.Scope = &v
- return s
- }
- type UpdateIPSetOutput struct {
- _ struct{} `type:"structure"`
- // A token used for optimistic locking. WAF returns this token to your update
- // requests. You use NextLockToken in the same manner as you use LockToken.
- NextLockToken *string `min:"1" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s UpdateIPSetOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s UpdateIPSetOutput) GoString() string {
- return s.String()
- }
- // SetNextLockToken sets the NextLockToken field's value.
- func (s *UpdateIPSetOutput) SetNextLockToken(v string) *UpdateIPSetOutput {
- s.NextLockToken = &v
- return s
- }
- type UpdateManagedRuleSetVersionExpiryDateInput struct {
- _ struct{} `type:"structure"`
- // The time that you want the version to expire.
- //
- // Times are in Coordinated Universal Time (UTC) format. UTC format includes
- // the special designator, Z. For example, "2016-09-27T14:50Z".
- //
- // ExpiryTimestamp is a required field
- ExpiryTimestamp *time.Time `type:"timestamp" required:"true"`
- // A unique identifier for the managed rule set. The ID is returned in the responses
- // to commands like list. You provide it to operations like get and update.
- //
- // Id is a required field
- Id *string `min:"1" type:"string" required:"true"`
- // A token used for optimistic locking. WAF returns a token to your get and
- // list requests, to mark the state of the entity at the time of the request.
- // To make changes to the entity associated with the token, you provide the
- // token to operations like update and delete. WAF uses the token to ensure
- // that no changes have been made to the entity since you last retrieved it.
- // If a change has been made, the update fails with a WAFOptimisticLockException.
- // If this happens, perform another get, and use the new token returned by that
- // operation.
- //
- // LockToken is a required field
- LockToken *string `min:"1" type:"string" required:"true"`
- // The name of the managed rule set. You use this, along with the rule set ID,
- // to identify the rule set.
- //
- // This name is assigned to the corresponding managed rule group, which your
- // customers can access and use.
- //
- // Name is a required field
- Name *string `min:"1" type:"string" required:"true"`
- // Specifies whether this is for an Amazon CloudFront distribution or for a
- // regional application. A regional application can be an Application Load Balancer
- // (ALB), an Amazon API Gateway REST API, an AppSync GraphQL API, or an Amazon
- // Cognito user pool.
- //
- // To work with CloudFront, you must also specify the Region US East (N. Virginia)
- // as follows:
- //
- // * CLI - Specify the Region when you use the CloudFront scope: --scope=CLOUDFRONT
- // --region=us-east-1.
- //
- // * API and SDKs - For all calls, use the Region endpoint us-east-1.
- //
- // Scope is a required field
- Scope *string `type:"string" required:"true" enum:"Scope"`
- // The version that you want to remove from your list of offerings for the named
- // managed rule group.
- //
- // VersionToExpire is a required field
- VersionToExpire *string `min:"1" type:"string" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s UpdateManagedRuleSetVersionExpiryDateInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s UpdateManagedRuleSetVersionExpiryDateInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *UpdateManagedRuleSetVersionExpiryDateInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "UpdateManagedRuleSetVersionExpiryDateInput"}
- if s.ExpiryTimestamp == nil {
- invalidParams.Add(request.NewErrParamRequired("ExpiryTimestamp"))
- }
- if s.Id == nil {
- invalidParams.Add(request.NewErrParamRequired("Id"))
- }
- if s.Id != nil && len(*s.Id) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Id", 1))
- }
- if s.LockToken == nil {
- invalidParams.Add(request.NewErrParamRequired("LockToken"))
- }
- if s.LockToken != nil && len(*s.LockToken) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("LockToken", 1))
- }
- if s.Name == nil {
- invalidParams.Add(request.NewErrParamRequired("Name"))
- }
- if s.Name != nil && len(*s.Name) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Name", 1))
- }
- if s.Scope == nil {
- invalidParams.Add(request.NewErrParamRequired("Scope"))
- }
- if s.VersionToExpire == nil {
- invalidParams.Add(request.NewErrParamRequired("VersionToExpire"))
- }
- if s.VersionToExpire != nil && len(*s.VersionToExpire) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("VersionToExpire", 1))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetExpiryTimestamp sets the ExpiryTimestamp field's value.
- func (s *UpdateManagedRuleSetVersionExpiryDateInput) SetExpiryTimestamp(v time.Time) *UpdateManagedRuleSetVersionExpiryDateInput {
- s.ExpiryTimestamp = &v
- return s
- }
- // SetId sets the Id field's value.
- func (s *UpdateManagedRuleSetVersionExpiryDateInput) SetId(v string) *UpdateManagedRuleSetVersionExpiryDateInput {
- s.Id = &v
- return s
- }
- // SetLockToken sets the LockToken field's value.
- func (s *UpdateManagedRuleSetVersionExpiryDateInput) SetLockToken(v string) *UpdateManagedRuleSetVersionExpiryDateInput {
- s.LockToken = &v
- return s
- }
- // SetName sets the Name field's value.
- func (s *UpdateManagedRuleSetVersionExpiryDateInput) SetName(v string) *UpdateManagedRuleSetVersionExpiryDateInput {
- s.Name = &v
- return s
- }
- // SetScope sets the Scope field's value.
- func (s *UpdateManagedRuleSetVersionExpiryDateInput) SetScope(v string) *UpdateManagedRuleSetVersionExpiryDateInput {
- s.Scope = &v
- return s
- }
- // SetVersionToExpire sets the VersionToExpire field's value.
- func (s *UpdateManagedRuleSetVersionExpiryDateInput) SetVersionToExpire(v string) *UpdateManagedRuleSetVersionExpiryDateInput {
- s.VersionToExpire = &v
- return s
- }
- type UpdateManagedRuleSetVersionExpiryDateOutput struct {
- _ struct{} `type:"structure"`
- // The version that is set to expire.
- ExpiringVersion *string `min:"1" type:"string"`
- // The time that the version will expire.
- //
- // Times are in Coordinated Universal Time (UTC) format. UTC format includes
- // the special designator, Z. For example, "2016-09-27T14:50Z".
- ExpiryTimestamp *time.Time `type:"timestamp"`
- // A token used for optimistic locking. WAF returns a token to your get and
- // list requests, to mark the state of the entity at the time of the request.
- // To make changes to the entity associated with the token, you provide the
- // token to operations like update and delete. WAF uses the token to ensure
- // that no changes have been made to the entity since you last retrieved it.
- // If a change has been made, the update fails with a WAFOptimisticLockException.
- // If this happens, perform another get, and use the new token returned by that
- // operation.
- NextLockToken *string `min:"1" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s UpdateManagedRuleSetVersionExpiryDateOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s UpdateManagedRuleSetVersionExpiryDateOutput) GoString() string {
- return s.String()
- }
- // SetExpiringVersion sets the ExpiringVersion field's value.
- func (s *UpdateManagedRuleSetVersionExpiryDateOutput) SetExpiringVersion(v string) *UpdateManagedRuleSetVersionExpiryDateOutput {
- s.ExpiringVersion = &v
- return s
- }
- // SetExpiryTimestamp sets the ExpiryTimestamp field's value.
- func (s *UpdateManagedRuleSetVersionExpiryDateOutput) SetExpiryTimestamp(v time.Time) *UpdateManagedRuleSetVersionExpiryDateOutput {
- s.ExpiryTimestamp = &v
- return s
- }
- // SetNextLockToken sets the NextLockToken field's value.
- func (s *UpdateManagedRuleSetVersionExpiryDateOutput) SetNextLockToken(v string) *UpdateManagedRuleSetVersionExpiryDateOutput {
- s.NextLockToken = &v
- return s
- }
- type UpdateRegexPatternSetInput struct {
- _ struct{} `type:"structure"`
- // A description of the set that helps with identification.
- Description *string `min:"1" type:"string"`
- // A unique identifier for the set. This ID is returned in the responses to
- // create and list commands. You provide it to operations like update and delete.
- //
- // Id is a required field
- Id *string `min:"1" type:"string" required:"true"`
- // A token used for optimistic locking. WAF returns a token to your get and
- // list requests, to mark the state of the entity at the time of the request.
- // To make changes to the entity associated with the token, you provide the
- // token to operations like update and delete. WAF uses the token to ensure
- // that no changes have been made to the entity since you last retrieved it.
- // If a change has been made, the update fails with a WAFOptimisticLockException.
- // If this happens, perform another get, and use the new token returned by that
- // operation.
- //
- // LockToken is a required field
- LockToken *string `min:"1" type:"string" required:"true"`
- // The name of the set. You cannot change the name after you create the set.
- //
- // Name is a required field
- Name *string `min:"1" type:"string" required:"true"`
- // RegularExpressionList is a required field
- RegularExpressionList []*Regex `type:"list" required:"true"`
- // Specifies whether this is for an Amazon CloudFront distribution or for a
- // regional application. A regional application can be an Application Load Balancer
- // (ALB), an Amazon API Gateway REST API, an AppSync GraphQL API, or an Amazon
- // Cognito user pool.
- //
- // To work with CloudFront, you must also specify the Region US East (N. Virginia)
- // as follows:
- //
- // * CLI - Specify the Region when you use the CloudFront scope: --scope=CLOUDFRONT
- // --region=us-east-1.
- //
- // * API and SDKs - For all calls, use the Region endpoint us-east-1.
- //
- // Scope is a required field
- Scope *string `type:"string" required:"true" enum:"Scope"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s UpdateRegexPatternSetInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s UpdateRegexPatternSetInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *UpdateRegexPatternSetInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "UpdateRegexPatternSetInput"}
- if s.Description != nil && len(*s.Description) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Description", 1))
- }
- if s.Id == nil {
- invalidParams.Add(request.NewErrParamRequired("Id"))
- }
- if s.Id != nil && len(*s.Id) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Id", 1))
- }
- if s.LockToken == nil {
- invalidParams.Add(request.NewErrParamRequired("LockToken"))
- }
- if s.LockToken != nil && len(*s.LockToken) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("LockToken", 1))
- }
- if s.Name == nil {
- invalidParams.Add(request.NewErrParamRequired("Name"))
- }
- if s.Name != nil && len(*s.Name) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Name", 1))
- }
- if s.RegularExpressionList == nil {
- invalidParams.Add(request.NewErrParamRequired("RegularExpressionList"))
- }
- if s.Scope == nil {
- invalidParams.Add(request.NewErrParamRequired("Scope"))
- }
- if s.RegularExpressionList != nil {
- for i, v := range s.RegularExpressionList {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "RegularExpressionList", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetDescription sets the Description field's value.
- func (s *UpdateRegexPatternSetInput) SetDescription(v string) *UpdateRegexPatternSetInput {
- s.Description = &v
- return s
- }
- // SetId sets the Id field's value.
- func (s *UpdateRegexPatternSetInput) SetId(v string) *UpdateRegexPatternSetInput {
- s.Id = &v
- return s
- }
- // SetLockToken sets the LockToken field's value.
- func (s *UpdateRegexPatternSetInput) SetLockToken(v string) *UpdateRegexPatternSetInput {
- s.LockToken = &v
- return s
- }
- // SetName sets the Name field's value.
- func (s *UpdateRegexPatternSetInput) SetName(v string) *UpdateRegexPatternSetInput {
- s.Name = &v
- return s
- }
- // SetRegularExpressionList sets the RegularExpressionList field's value.
- func (s *UpdateRegexPatternSetInput) SetRegularExpressionList(v []*Regex) *UpdateRegexPatternSetInput {
- s.RegularExpressionList = v
- return s
- }
- // SetScope sets the Scope field's value.
- func (s *UpdateRegexPatternSetInput) SetScope(v string) *UpdateRegexPatternSetInput {
- s.Scope = &v
- return s
- }
- type UpdateRegexPatternSetOutput struct {
- _ struct{} `type:"structure"`
- // A token used for optimistic locking. WAF returns this token to your update
- // requests. You use NextLockToken in the same manner as you use LockToken.
- NextLockToken *string `min:"1" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s UpdateRegexPatternSetOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s UpdateRegexPatternSetOutput) GoString() string {
- return s.String()
- }
- // SetNextLockToken sets the NextLockToken field's value.
- func (s *UpdateRegexPatternSetOutput) SetNextLockToken(v string) *UpdateRegexPatternSetOutput {
- s.NextLockToken = &v
- return s
- }
- type UpdateRuleGroupInput struct {
- _ struct{} `type:"structure"`
- // A map of custom response keys and content bodies. When you create a rule
- // with a block action, you can send a custom response to the web request. You
- // define these for the rule group, and then use them in the rules that you
- // define in the rule group.
- //
- // For information about customizing web requests and responses, see Customizing
- // web requests and responses in WAF (https://docs.aws.amazon.com/waf/latest/developerguide/waf-custom-request-response.html)
- // in the WAF Developer Guide (https://docs.aws.amazon.com/waf/latest/developerguide/waf-chapter.html).
- //
- // For information about the limits on count and size for custom request and
- // response settings, see WAF quotas (https://docs.aws.amazon.com/waf/latest/developerguide/limits.html)
- // in the WAF Developer Guide (https://docs.aws.amazon.com/waf/latest/developerguide/waf-chapter.html).
- CustomResponseBodies map[string]*CustomResponseBody `min:"1" type:"map"`
- // A description of the rule group that helps with identification.
- Description *string `min:"1" type:"string"`
- // A unique identifier for the rule group. This ID is returned in the responses
- // to create and list commands. You provide it to operations like update and
- // delete.
- //
- // Id is a required field
- Id *string `min:"1" type:"string" required:"true"`
- // A token used for optimistic locking. WAF returns a token to your get and
- // list requests, to mark the state of the entity at the time of the request.
- // To make changes to the entity associated with the token, you provide the
- // token to operations like update and delete. WAF uses the token to ensure
- // that no changes have been made to the entity since you last retrieved it.
- // If a change has been made, the update fails with a WAFOptimisticLockException.
- // If this happens, perform another get, and use the new token returned by that
- // operation.
- //
- // LockToken is a required field
- LockToken *string `min:"1" type:"string" required:"true"`
- // The name of the rule group. You cannot change the name of a rule group after
- // you create it.
- //
- // Name is a required field
- Name *string `min:"1" type:"string" required:"true"`
- // The Rule statements used to identify the web requests that you want to allow,
- // block, or count. Each rule includes one top-level statement that WAF uses
- // to identify matching web requests, and parameters that govern how WAF handles
- // them.
- Rules []*Rule `type:"list"`
- // Specifies whether this is for an Amazon CloudFront distribution or for a
- // regional application. A regional application can be an Application Load Balancer
- // (ALB), an Amazon API Gateway REST API, an AppSync GraphQL API, or an Amazon
- // Cognito user pool.
- //
- // To work with CloudFront, you must also specify the Region US East (N. Virginia)
- // as follows:
- //
- // * CLI - Specify the Region when you use the CloudFront scope: --scope=CLOUDFRONT
- // --region=us-east-1.
- //
- // * API and SDKs - For all calls, use the Region endpoint us-east-1.
- //
- // Scope is a required field
- Scope *string `type:"string" required:"true" enum:"Scope"`
- // Defines and enables Amazon CloudWatch metrics and web request sample collection.
- //
- // VisibilityConfig is a required field
- VisibilityConfig *VisibilityConfig `type:"structure" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s UpdateRuleGroupInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s UpdateRuleGroupInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *UpdateRuleGroupInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "UpdateRuleGroupInput"}
- if s.CustomResponseBodies != nil && len(s.CustomResponseBodies) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("CustomResponseBodies", 1))
- }
- if s.Description != nil && len(*s.Description) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Description", 1))
- }
- if s.Id == nil {
- invalidParams.Add(request.NewErrParamRequired("Id"))
- }
- if s.Id != nil && len(*s.Id) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Id", 1))
- }
- if s.LockToken == nil {
- invalidParams.Add(request.NewErrParamRequired("LockToken"))
- }
- if s.LockToken != nil && len(*s.LockToken) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("LockToken", 1))
- }
- if s.Name == nil {
- invalidParams.Add(request.NewErrParamRequired("Name"))
- }
- if s.Name != nil && len(*s.Name) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Name", 1))
- }
- if s.Scope == nil {
- invalidParams.Add(request.NewErrParamRequired("Scope"))
- }
- if s.VisibilityConfig == nil {
- invalidParams.Add(request.NewErrParamRequired("VisibilityConfig"))
- }
- if s.CustomResponseBodies != nil {
- for i, v := range s.CustomResponseBodies {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "CustomResponseBodies", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if s.Rules != nil {
- for i, v := range s.Rules {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "Rules", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if s.VisibilityConfig != nil {
- if err := s.VisibilityConfig.Validate(); err != nil {
- invalidParams.AddNested("VisibilityConfig", err.(request.ErrInvalidParams))
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetCustomResponseBodies sets the CustomResponseBodies field's value.
- func (s *UpdateRuleGroupInput) SetCustomResponseBodies(v map[string]*CustomResponseBody) *UpdateRuleGroupInput {
- s.CustomResponseBodies = v
- return s
- }
- // SetDescription sets the Description field's value.
- func (s *UpdateRuleGroupInput) SetDescription(v string) *UpdateRuleGroupInput {
- s.Description = &v
- return s
- }
- // SetId sets the Id field's value.
- func (s *UpdateRuleGroupInput) SetId(v string) *UpdateRuleGroupInput {
- s.Id = &v
- return s
- }
- // SetLockToken sets the LockToken field's value.
- func (s *UpdateRuleGroupInput) SetLockToken(v string) *UpdateRuleGroupInput {
- s.LockToken = &v
- return s
- }
- // SetName sets the Name field's value.
- func (s *UpdateRuleGroupInput) SetName(v string) *UpdateRuleGroupInput {
- s.Name = &v
- return s
- }
- // SetRules sets the Rules field's value.
- func (s *UpdateRuleGroupInput) SetRules(v []*Rule) *UpdateRuleGroupInput {
- s.Rules = v
- return s
- }
- // SetScope sets the Scope field's value.
- func (s *UpdateRuleGroupInput) SetScope(v string) *UpdateRuleGroupInput {
- s.Scope = &v
- return s
- }
- // SetVisibilityConfig sets the VisibilityConfig field's value.
- func (s *UpdateRuleGroupInput) SetVisibilityConfig(v *VisibilityConfig) *UpdateRuleGroupInput {
- s.VisibilityConfig = v
- return s
- }
- type UpdateRuleGroupOutput struct {
- _ struct{} `type:"structure"`
- // A token used for optimistic locking. WAF returns this token to your update
- // requests. You use NextLockToken in the same manner as you use LockToken.
- NextLockToken *string `min:"1" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s UpdateRuleGroupOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s UpdateRuleGroupOutput) GoString() string {
- return s.String()
- }
- // SetNextLockToken sets the NextLockToken field's value.
- func (s *UpdateRuleGroupOutput) SetNextLockToken(v string) *UpdateRuleGroupOutput {
- s.NextLockToken = &v
- return s
- }
- type UpdateWebACLInput struct {
- _ struct{} `type:"structure"`
- // Specifies how WAF should handle CAPTCHA evaluations for rules that don't
- // have their own CaptchaConfig settings. If you don't specify this, WAF uses
- // its default settings for CaptchaConfig.
- CaptchaConfig *CaptchaConfig `type:"structure"`
- // Specifies how WAF should handle challenge evaluations for rules that don't
- // have their own ChallengeConfig settings. If you don't specify this, WAF uses
- // its default settings for ChallengeConfig.
- ChallengeConfig *ChallengeConfig `type:"structure"`
- // A map of custom response keys and content bodies. When you create a rule
- // with a block action, you can send a custom response to the web request. You
- // define these for the web ACL, and then use them in the rules and default
- // actions that you define in the web ACL.
- //
- // For information about customizing web requests and responses, see Customizing
- // web requests and responses in WAF (https://docs.aws.amazon.com/waf/latest/developerguide/waf-custom-request-response.html)
- // in the WAF Developer Guide (https://docs.aws.amazon.com/waf/latest/developerguide/waf-chapter.html).
- //
- // For information about the limits on count and size for custom request and
- // response settings, see WAF quotas (https://docs.aws.amazon.com/waf/latest/developerguide/limits.html)
- // in the WAF Developer Guide (https://docs.aws.amazon.com/waf/latest/developerguide/waf-chapter.html).
- CustomResponseBodies map[string]*CustomResponseBody `min:"1" type:"map"`
- // The action to perform if none of the Rules contained in the WebACL match.
- //
- // DefaultAction is a required field
- DefaultAction *DefaultAction `type:"structure" required:"true"`
- // A description of the web ACL that helps with identification.
- Description *string `min:"1" type:"string"`
- // The unique identifier for the web ACL. This ID is returned in the responses
- // to create and list commands. You provide it to operations like update and
- // delete.
- //
- // Id is a required field
- Id *string `min:"1" type:"string" required:"true"`
- // A token used for optimistic locking. WAF returns a token to your get and
- // list requests, to mark the state of the entity at the time of the request.
- // To make changes to the entity associated with the token, you provide the
- // token to operations like update and delete. WAF uses the token to ensure
- // that no changes have been made to the entity since you last retrieved it.
- // If a change has been made, the update fails with a WAFOptimisticLockException.
- // If this happens, perform another get, and use the new token returned by that
- // operation.
- //
- // LockToken is a required field
- LockToken *string `min:"1" type:"string" required:"true"`
- // The name of the web ACL. You cannot change the name of a web ACL after you
- // create it.
- //
- // Name is a required field
- Name *string `min:"1" type:"string" required:"true"`
- // The Rule statements used to identify the web requests that you want to allow,
- // block, or count. Each rule includes one top-level statement that WAF uses
- // to identify matching web requests, and parameters that govern how WAF handles
- // them.
- Rules []*Rule `type:"list"`
- // Specifies whether this is for an Amazon CloudFront distribution or for a
- // regional application. A regional application can be an Application Load Balancer
- // (ALB), an Amazon API Gateway REST API, an AppSync GraphQL API, or an Amazon
- // Cognito user pool.
- //
- // To work with CloudFront, you must also specify the Region US East (N. Virginia)
- // as follows:
- //
- // * CLI - Specify the Region when you use the CloudFront scope: --scope=CLOUDFRONT
- // --region=us-east-1.
- //
- // * API and SDKs - For all calls, use the Region endpoint us-east-1.
- //
- // Scope is a required field
- Scope *string `type:"string" required:"true" enum:"Scope"`
- // Specifies the domains that WAF should accept in a web request token. This
- // enables the use of tokens across multiple protected websites. When WAF provides
- // a token, it uses the domain of the Amazon Web Services resource that the
- // web ACL is protecting. If you don't specify a list of token domains, WAF
- // accepts tokens only for the domain of the protected resource. With a token
- // domain list, WAF accepts the resource's host domain plus all domains in the
- // token domain list, including their prefixed subdomains.
- //
- // Example JSON: "TokenDomains": { "mywebsite.com", "myotherwebsite.com" }
- //
- // Public suffixes aren't allowed. For example, you can't use usa.gov or co.uk
- // as token domains.
- TokenDomains []*string `min:"1" type:"list"`
- // Defines and enables Amazon CloudWatch metrics and web request sample collection.
- //
- // VisibilityConfig is a required field
- VisibilityConfig *VisibilityConfig `type:"structure" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s UpdateWebACLInput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s UpdateWebACLInput) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *UpdateWebACLInput) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "UpdateWebACLInput"}
- if s.CustomResponseBodies != nil && len(s.CustomResponseBodies) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("CustomResponseBodies", 1))
- }
- if s.DefaultAction == nil {
- invalidParams.Add(request.NewErrParamRequired("DefaultAction"))
- }
- if s.Description != nil && len(*s.Description) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Description", 1))
- }
- if s.Id == nil {
- invalidParams.Add(request.NewErrParamRequired("Id"))
- }
- if s.Id != nil && len(*s.Id) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Id", 1))
- }
- if s.LockToken == nil {
- invalidParams.Add(request.NewErrParamRequired("LockToken"))
- }
- if s.LockToken != nil && len(*s.LockToken) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("LockToken", 1))
- }
- if s.Name == nil {
- invalidParams.Add(request.NewErrParamRequired("Name"))
- }
- if s.Name != nil && len(*s.Name) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Name", 1))
- }
- if s.Scope == nil {
- invalidParams.Add(request.NewErrParamRequired("Scope"))
- }
- if s.TokenDomains != nil && len(s.TokenDomains) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("TokenDomains", 1))
- }
- if s.VisibilityConfig == nil {
- invalidParams.Add(request.NewErrParamRequired("VisibilityConfig"))
- }
- if s.CaptchaConfig != nil {
- if err := s.CaptchaConfig.Validate(); err != nil {
- invalidParams.AddNested("CaptchaConfig", err.(request.ErrInvalidParams))
- }
- }
- if s.ChallengeConfig != nil {
- if err := s.ChallengeConfig.Validate(); err != nil {
- invalidParams.AddNested("ChallengeConfig", err.(request.ErrInvalidParams))
- }
- }
- if s.CustomResponseBodies != nil {
- for i, v := range s.CustomResponseBodies {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "CustomResponseBodies", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if s.DefaultAction != nil {
- if err := s.DefaultAction.Validate(); err != nil {
- invalidParams.AddNested("DefaultAction", err.(request.ErrInvalidParams))
- }
- }
- if s.Rules != nil {
- for i, v := range s.Rules {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "Rules", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if s.VisibilityConfig != nil {
- if err := s.VisibilityConfig.Validate(); err != nil {
- invalidParams.AddNested("VisibilityConfig", err.(request.ErrInvalidParams))
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetCaptchaConfig sets the CaptchaConfig field's value.
- func (s *UpdateWebACLInput) SetCaptchaConfig(v *CaptchaConfig) *UpdateWebACLInput {
- s.CaptchaConfig = v
- return s
- }
- // SetChallengeConfig sets the ChallengeConfig field's value.
- func (s *UpdateWebACLInput) SetChallengeConfig(v *ChallengeConfig) *UpdateWebACLInput {
- s.ChallengeConfig = v
- return s
- }
- // SetCustomResponseBodies sets the CustomResponseBodies field's value.
- func (s *UpdateWebACLInput) SetCustomResponseBodies(v map[string]*CustomResponseBody) *UpdateWebACLInput {
- s.CustomResponseBodies = v
- return s
- }
- // SetDefaultAction sets the DefaultAction field's value.
- func (s *UpdateWebACLInput) SetDefaultAction(v *DefaultAction) *UpdateWebACLInput {
- s.DefaultAction = v
- return s
- }
- // SetDescription sets the Description field's value.
- func (s *UpdateWebACLInput) SetDescription(v string) *UpdateWebACLInput {
- s.Description = &v
- return s
- }
- // SetId sets the Id field's value.
- func (s *UpdateWebACLInput) SetId(v string) *UpdateWebACLInput {
- s.Id = &v
- return s
- }
- // SetLockToken sets the LockToken field's value.
- func (s *UpdateWebACLInput) SetLockToken(v string) *UpdateWebACLInput {
- s.LockToken = &v
- return s
- }
- // SetName sets the Name field's value.
- func (s *UpdateWebACLInput) SetName(v string) *UpdateWebACLInput {
- s.Name = &v
- return s
- }
- // SetRules sets the Rules field's value.
- func (s *UpdateWebACLInput) SetRules(v []*Rule) *UpdateWebACLInput {
- s.Rules = v
- return s
- }
- // SetScope sets the Scope field's value.
- func (s *UpdateWebACLInput) SetScope(v string) *UpdateWebACLInput {
- s.Scope = &v
- return s
- }
- // SetTokenDomains sets the TokenDomains field's value.
- func (s *UpdateWebACLInput) SetTokenDomains(v []*string) *UpdateWebACLInput {
- s.TokenDomains = v
- return s
- }
- // SetVisibilityConfig sets the VisibilityConfig field's value.
- func (s *UpdateWebACLInput) SetVisibilityConfig(v *VisibilityConfig) *UpdateWebACLInput {
- s.VisibilityConfig = v
- return s
- }
- type UpdateWebACLOutput struct {
- _ struct{} `type:"structure"`
- // A token used for optimistic locking. WAF returns this token to your update
- // requests. You use NextLockToken in the same manner as you use LockToken.
- NextLockToken *string `min:"1" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s UpdateWebACLOutput) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s UpdateWebACLOutput) GoString() string {
- return s.String()
- }
- // SetNextLockToken sets the NextLockToken field's value.
- func (s *UpdateWebACLOutput) SetNextLockToken(v string) *UpdateWebACLOutput {
- s.NextLockToken = &v
- return s
- }
- // Inspect the path component of the URI of the web request. This is the part
- // of the web request that identifies a resource. For example, /images/daily-ad.jpg.
- //
- // This is used only in the FieldToMatch specification for some web request
- // component types.
- //
- // JSON specification: "UriPath": {}
- type UriPath struct {
- _ struct{} `type:"structure"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s UriPath) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s UriPath) GoString() string {
- return s.String()
- }
- // Details about your login page username field, used in a ManagedRuleGroupConfig.
- type UsernameField struct {
- _ struct{} `type:"structure"`
- // The name of the username field. For example /form/username.
- //
- // Identifier is a required field
- Identifier *string `min:"1" type:"string" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s UsernameField) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s UsernameField) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *UsernameField) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "UsernameField"}
- if s.Identifier == nil {
- invalidParams.Add(request.NewErrParamRequired("Identifier"))
- }
- if s.Identifier != nil && len(*s.Identifier) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("Identifier", 1))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetIdentifier sets the Identifier field's value.
- func (s *UsernameField) SetIdentifier(v string) *UsernameField {
- s.Identifier = &v
- return s
- }
- // A version of the named managed rule group, that the rule group's vendor publishes
- // for use by customers.
- //
- // This is intended for use only by vendors of managed rule sets. Vendors are
- // Amazon Web Services and Amazon Web Services Marketplace sellers.
- //
- // Vendors, you can use the managed rule set APIs to provide controlled rollout
- // of your versioned managed rule group offerings for your customers. The APIs
- // are ListManagedRuleSets, GetManagedRuleSet, PutManagedRuleSetVersions, and
- // UpdateManagedRuleSetVersionExpiryDate.
- type VersionToPublish struct {
- _ struct{} `type:"structure"`
- // The Amazon Resource Name (ARN) of the vendor's rule group that's used in
- // the published managed rule group version.
- AssociatedRuleGroupArn *string `min:"20" type:"string"`
- // The amount of time the vendor expects this version of the managed rule group
- // to last, in days.
- ForecastedLifetime *int64 `min:"1" type:"integer"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s VersionToPublish) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s VersionToPublish) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *VersionToPublish) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "VersionToPublish"}
- if s.AssociatedRuleGroupArn != nil && len(*s.AssociatedRuleGroupArn) < 20 {
- invalidParams.Add(request.NewErrParamMinLen("AssociatedRuleGroupArn", 20))
- }
- if s.ForecastedLifetime != nil && *s.ForecastedLifetime < 1 {
- invalidParams.Add(request.NewErrParamMinValue("ForecastedLifetime", 1))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetAssociatedRuleGroupArn sets the AssociatedRuleGroupArn field's value.
- func (s *VersionToPublish) SetAssociatedRuleGroupArn(v string) *VersionToPublish {
- s.AssociatedRuleGroupArn = &v
- return s
- }
- // SetForecastedLifetime sets the ForecastedLifetime field's value.
- func (s *VersionToPublish) SetForecastedLifetime(v int64) *VersionToPublish {
- s.ForecastedLifetime = &v
- return s
- }
- // Defines and enables Amazon CloudWatch metrics and web request sample collection.
- type VisibilityConfig struct {
- _ struct{} `type:"structure"`
- // A boolean indicating whether the associated resource sends metrics to Amazon
- // CloudWatch. For the list of available metrics, see WAF Metrics (https://docs.aws.amazon.com/waf/latest/developerguide/monitoring-cloudwatch.html#waf-metrics).
- //
- // CloudWatchMetricsEnabled is a required field
- CloudWatchMetricsEnabled *bool `type:"boolean" required:"true"`
- // A name of the Amazon CloudWatch metric dimension. The name can contain only
- // the characters: A-Z, a-z, 0-9, - (hyphen), and _ (underscore). The name can
- // be from one to 128 characters long. It can't contain whitespace or metric
- // names that are reserved for WAF, for example All and Default_Action.
- //
- // MetricName is a required field
- MetricName *string `min:"1" type:"string" required:"true"`
- // A boolean indicating whether WAF should store a sampling of the web requests
- // that match the rules. You can view the sampled requests through the WAF console.
- //
- // SampledRequestsEnabled is a required field
- SampledRequestsEnabled *bool `type:"boolean" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s VisibilityConfig) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s VisibilityConfig) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *VisibilityConfig) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "VisibilityConfig"}
- if s.CloudWatchMetricsEnabled == nil {
- invalidParams.Add(request.NewErrParamRequired("CloudWatchMetricsEnabled"))
- }
- if s.MetricName == nil {
- invalidParams.Add(request.NewErrParamRequired("MetricName"))
- }
- if s.MetricName != nil && len(*s.MetricName) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("MetricName", 1))
- }
- if s.SampledRequestsEnabled == nil {
- invalidParams.Add(request.NewErrParamRequired("SampledRequestsEnabled"))
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetCloudWatchMetricsEnabled sets the CloudWatchMetricsEnabled field's value.
- func (s *VisibilityConfig) SetCloudWatchMetricsEnabled(v bool) *VisibilityConfig {
- s.CloudWatchMetricsEnabled = &v
- return s
- }
- // SetMetricName sets the MetricName field's value.
- func (s *VisibilityConfig) SetMetricName(v string) *VisibilityConfig {
- s.MetricName = &v
- return s
- }
- // SetSampledRequestsEnabled sets the SampledRequestsEnabled field's value.
- func (s *VisibilityConfig) SetSampledRequestsEnabled(v bool) *VisibilityConfig {
- s.SampledRequestsEnabled = &v
- return s
- }
- // WAF couldn’t perform the operation because your resource is being used
- // by another resource or it’s associated with another resource.
- type WAFAssociatedItemException struct {
- _ struct{} `type:"structure"`
- RespMetadata protocol.ResponseMetadata `json:"-" xml:"-"`
- Message_ *string `locationName:"Message" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s WAFAssociatedItemException) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s WAFAssociatedItemException) GoString() string {
- return s.String()
- }
- func newErrorWAFAssociatedItemException(v protocol.ResponseMetadata) error {
- return &WAFAssociatedItemException{
- RespMetadata: v,
- }
- }
- // Code returns the exception type name.
- func (s *WAFAssociatedItemException) Code() string {
- return "WAFAssociatedItemException"
- }
- // Message returns the exception's message.
- func (s *WAFAssociatedItemException) Message() string {
- if s.Message_ != nil {
- return *s.Message_
- }
- return ""
- }
- // OrigErr always returns nil, satisfies awserr.Error interface.
- func (s *WAFAssociatedItemException) OrigErr() error {
- return nil
- }
- func (s *WAFAssociatedItemException) Error() string {
- return fmt.Sprintf("%s: %s", s.Code(), s.Message())
- }
- // Status code returns the HTTP status code for the request's response error.
- func (s *WAFAssociatedItemException) StatusCode() int {
- return s.RespMetadata.StatusCode
- }
- // RequestID returns the service's response RequestID for request.
- func (s *WAFAssociatedItemException) RequestID() string {
- return s.RespMetadata.RequestID
- }
- // The operation failed because you are inspecting the web request body, headers,
- // or cookies without specifying how to handle oversize components. Rules that
- // inspect the body must either provide an OversizeHandling configuration or
- // they must be preceded by a SizeConstraintStatement that blocks the body content
- // from being too large. Rules that inspect the headers or cookies must provide
- // an OversizeHandling configuration.
- //
- // Provide the handling configuration and retry your operation.
- //
- // Alternately, you can suppress this warning by adding the following tag to
- // the resource that you provide to this operation: Tag (key:WAF:OversizeFieldsHandlingConstraintOptOut,
- // value:true).
- type WAFConfigurationWarningException struct {
- _ struct{} `type:"structure"`
- RespMetadata protocol.ResponseMetadata `json:"-" xml:"-"`
- Message_ *string `locationName:"Message" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s WAFConfigurationWarningException) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s WAFConfigurationWarningException) GoString() string {
- return s.String()
- }
- func newErrorWAFConfigurationWarningException(v protocol.ResponseMetadata) error {
- return &WAFConfigurationWarningException{
- RespMetadata: v,
- }
- }
- // Code returns the exception type name.
- func (s *WAFConfigurationWarningException) Code() string {
- return "WAFConfigurationWarningException"
- }
- // Message returns the exception's message.
- func (s *WAFConfigurationWarningException) Message() string {
- if s.Message_ != nil {
- return *s.Message_
- }
- return ""
- }
- // OrigErr always returns nil, satisfies awserr.Error interface.
- func (s *WAFConfigurationWarningException) OrigErr() error {
- return nil
- }
- func (s *WAFConfigurationWarningException) Error() string {
- return fmt.Sprintf("%s: %s", s.Code(), s.Message())
- }
- // Status code returns the HTTP status code for the request's response error.
- func (s *WAFConfigurationWarningException) StatusCode() int {
- return s.RespMetadata.StatusCode
- }
- // RequestID returns the service's response RequestID for request.
- func (s *WAFConfigurationWarningException) RequestID() string {
- return s.RespMetadata.RequestID
- }
- // WAF couldn’t perform the operation because the resource that you tried
- // to save is a duplicate of an existing one.
- type WAFDuplicateItemException struct {
- _ struct{} `type:"structure"`
- RespMetadata protocol.ResponseMetadata `json:"-" xml:"-"`
- Message_ *string `locationName:"Message" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s WAFDuplicateItemException) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s WAFDuplicateItemException) GoString() string {
- return s.String()
- }
- func newErrorWAFDuplicateItemException(v protocol.ResponseMetadata) error {
- return &WAFDuplicateItemException{
- RespMetadata: v,
- }
- }
- // Code returns the exception type name.
- func (s *WAFDuplicateItemException) Code() string {
- return "WAFDuplicateItemException"
- }
- // Message returns the exception's message.
- func (s *WAFDuplicateItemException) Message() string {
- if s.Message_ != nil {
- return *s.Message_
- }
- return ""
- }
- // OrigErr always returns nil, satisfies awserr.Error interface.
- func (s *WAFDuplicateItemException) OrigErr() error {
- return nil
- }
- func (s *WAFDuplicateItemException) Error() string {
- return fmt.Sprintf("%s: %s", s.Code(), s.Message())
- }
- // Status code returns the HTTP status code for the request's response error.
- func (s *WAFDuplicateItemException) StatusCode() int {
- return s.RespMetadata.StatusCode
- }
- // RequestID returns the service's response RequestID for request.
- func (s *WAFDuplicateItemException) RequestID() string {
- return s.RespMetadata.RequestID
- }
- // The operation failed because the specified version for the managed rule group
- // has expired. You can retrieve the available versions for the managed rule
- // group by calling ListAvailableManagedRuleGroupVersions.
- type WAFExpiredManagedRuleGroupVersionException struct {
- _ struct{} `type:"structure"`
- RespMetadata protocol.ResponseMetadata `json:"-" xml:"-"`
- Message_ *string `locationName:"Message" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s WAFExpiredManagedRuleGroupVersionException) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s WAFExpiredManagedRuleGroupVersionException) GoString() string {
- return s.String()
- }
- func newErrorWAFExpiredManagedRuleGroupVersionException(v protocol.ResponseMetadata) error {
- return &WAFExpiredManagedRuleGroupVersionException{
- RespMetadata: v,
- }
- }
- // Code returns the exception type name.
- func (s *WAFExpiredManagedRuleGroupVersionException) Code() string {
- return "WAFExpiredManagedRuleGroupVersionException"
- }
- // Message returns the exception's message.
- func (s *WAFExpiredManagedRuleGroupVersionException) Message() string {
- if s.Message_ != nil {
- return *s.Message_
- }
- return ""
- }
- // OrigErr always returns nil, satisfies awserr.Error interface.
- func (s *WAFExpiredManagedRuleGroupVersionException) OrigErr() error {
- return nil
- }
- func (s *WAFExpiredManagedRuleGroupVersionException) Error() string {
- return fmt.Sprintf("%s: %s", s.Code(), s.Message())
- }
- // Status code returns the HTTP status code for the request's response error.
- func (s *WAFExpiredManagedRuleGroupVersionException) StatusCode() int {
- return s.RespMetadata.StatusCode
- }
- // RequestID returns the service's response RequestID for request.
- func (s *WAFExpiredManagedRuleGroupVersionException) RequestID() string {
- return s.RespMetadata.RequestID
- }
- // Your request is valid, but WAF couldn’t perform the operation because of
- // a system problem. Retry your request.
- type WAFInternalErrorException struct {
- _ struct{} `type:"structure"`
- RespMetadata protocol.ResponseMetadata `json:"-" xml:"-"`
- Message_ *string `locationName:"Message" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s WAFInternalErrorException) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s WAFInternalErrorException) GoString() string {
- return s.String()
- }
- func newErrorWAFInternalErrorException(v protocol.ResponseMetadata) error {
- return &WAFInternalErrorException{
- RespMetadata: v,
- }
- }
- // Code returns the exception type name.
- func (s *WAFInternalErrorException) Code() string {
- return "WAFInternalErrorException"
- }
- // Message returns the exception's message.
- func (s *WAFInternalErrorException) Message() string {
- if s.Message_ != nil {
- return *s.Message_
- }
- return ""
- }
- // OrigErr always returns nil, satisfies awserr.Error interface.
- func (s *WAFInternalErrorException) OrigErr() error {
- return nil
- }
- func (s *WAFInternalErrorException) Error() string {
- return fmt.Sprintf("%s: %s", s.Code(), s.Message())
- }
- // Status code returns the HTTP status code for the request's response error.
- func (s *WAFInternalErrorException) StatusCode() int {
- return s.RespMetadata.StatusCode
- }
- // RequestID returns the service's response RequestID for request.
- func (s *WAFInternalErrorException) RequestID() string {
- return s.RespMetadata.RequestID
- }
- // The operation isn't valid.
- type WAFInvalidOperationException struct {
- _ struct{} `type:"structure"`
- RespMetadata protocol.ResponseMetadata `json:"-" xml:"-"`
- Message_ *string `locationName:"Message" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s WAFInvalidOperationException) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s WAFInvalidOperationException) GoString() string {
- return s.String()
- }
- func newErrorWAFInvalidOperationException(v protocol.ResponseMetadata) error {
- return &WAFInvalidOperationException{
- RespMetadata: v,
- }
- }
- // Code returns the exception type name.
- func (s *WAFInvalidOperationException) Code() string {
- return "WAFInvalidOperationException"
- }
- // Message returns the exception's message.
- func (s *WAFInvalidOperationException) Message() string {
- if s.Message_ != nil {
- return *s.Message_
- }
- return ""
- }
- // OrigErr always returns nil, satisfies awserr.Error interface.
- func (s *WAFInvalidOperationException) OrigErr() error {
- return nil
- }
- func (s *WAFInvalidOperationException) Error() string {
- return fmt.Sprintf("%s: %s", s.Code(), s.Message())
- }
- // Status code returns the HTTP status code for the request's response error.
- func (s *WAFInvalidOperationException) StatusCode() int {
- return s.RespMetadata.StatusCode
- }
- // RequestID returns the service's response RequestID for request.
- func (s *WAFInvalidOperationException) RequestID() string {
- return s.RespMetadata.RequestID
- }
- // The operation failed because WAF didn't recognize a parameter in the request.
- // For example:
- //
- // - You specified a parameter name or value that isn't valid.
- //
- // - Your nested statement isn't valid. You might have tried to nest a statement
- // that can’t be nested.
- //
- // - You tried to update a WebACL with a DefaultAction that isn't among the
- // types available at DefaultAction.
- //
- // - Your request references an ARN that is malformed, or corresponds to
- // a resource with which a web ACL can't be associated.
- type WAFInvalidParameterException struct {
- _ struct{} `type:"structure"`
- RespMetadata protocol.ResponseMetadata `json:"-" xml:"-"`
- // The settings where the invalid parameter was found.
- Field *string `type:"string" enum:"ParameterExceptionField"`
- Message_ *string `locationName:"message" type:"string"`
- // The invalid parameter that resulted in the exception.
- Parameter *string `min:"1" type:"string"`
- // Additional information about the exception.
- Reason *string `type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s WAFInvalidParameterException) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s WAFInvalidParameterException) GoString() string {
- return s.String()
- }
- func newErrorWAFInvalidParameterException(v protocol.ResponseMetadata) error {
- return &WAFInvalidParameterException{
- RespMetadata: v,
- }
- }
- // Code returns the exception type name.
- func (s *WAFInvalidParameterException) Code() string {
- return "WAFInvalidParameterException"
- }
- // Message returns the exception's message.
- func (s *WAFInvalidParameterException) Message() string {
- if s.Message_ != nil {
- return *s.Message_
- }
- return ""
- }
- // OrigErr always returns nil, satisfies awserr.Error interface.
- func (s *WAFInvalidParameterException) OrigErr() error {
- return nil
- }
- func (s *WAFInvalidParameterException) Error() string {
- return fmt.Sprintf("%s: %s\n%s", s.Code(), s.Message(), s.String())
- }
- // Status code returns the HTTP status code for the request's response error.
- func (s *WAFInvalidParameterException) StatusCode() int {
- return s.RespMetadata.StatusCode
- }
- // RequestID returns the service's response RequestID for request.
- func (s *WAFInvalidParameterException) RequestID() string {
- return s.RespMetadata.RequestID
- }
- // The operation failed because the specified policy isn't in the proper format.
- //
- // The policy specifications must conform to the following:
- //
- // - The policy must be composed using IAM Policy version 2012-10-17 or version
- // 2015-01-01.
- //
- // - The policy must include specifications for Effect, Action, and Principal.
- //
- // - Effect must specify Allow.
- //
- // - Action must specify wafv2:CreateWebACL, wafv2:UpdateWebACL, and wafv2:PutFirewallManagerRuleGroups
- // and may optionally specify wafv2:GetRuleGroup. WAF rejects any extra actions
- // or wildcard actions in the policy.
- //
- // - The policy must not include a Resource parameter.
- //
- // For more information, see IAM Policies (https://docs.aws.amazon.com/IAM/latest/UserGuide/access_policies.html).
- type WAFInvalidPermissionPolicyException struct {
- _ struct{} `type:"structure"`
- RespMetadata protocol.ResponseMetadata `json:"-" xml:"-"`
- Message_ *string `locationName:"Message" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s WAFInvalidPermissionPolicyException) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s WAFInvalidPermissionPolicyException) GoString() string {
- return s.String()
- }
- func newErrorWAFInvalidPermissionPolicyException(v protocol.ResponseMetadata) error {
- return &WAFInvalidPermissionPolicyException{
- RespMetadata: v,
- }
- }
- // Code returns the exception type name.
- func (s *WAFInvalidPermissionPolicyException) Code() string {
- return "WAFInvalidPermissionPolicyException"
- }
- // Message returns the exception's message.
- func (s *WAFInvalidPermissionPolicyException) Message() string {
- if s.Message_ != nil {
- return *s.Message_
- }
- return ""
- }
- // OrigErr always returns nil, satisfies awserr.Error interface.
- func (s *WAFInvalidPermissionPolicyException) OrigErr() error {
- return nil
- }
- func (s *WAFInvalidPermissionPolicyException) Error() string {
- return fmt.Sprintf("%s: %s", s.Code(), s.Message())
- }
- // Status code returns the HTTP status code for the request's response error.
- func (s *WAFInvalidPermissionPolicyException) StatusCode() int {
- return s.RespMetadata.StatusCode
- }
- // RequestID returns the service's response RequestID for request.
- func (s *WAFInvalidPermissionPolicyException) RequestID() string {
- return s.RespMetadata.RequestID
- }
- // WAF couldn’t perform the operation because the resource that you requested
- // isn’t valid. Check the resource, and try again.
- type WAFInvalidResourceException struct {
- _ struct{} `type:"structure"`
- RespMetadata protocol.ResponseMetadata `json:"-" xml:"-"`
- Message_ *string `locationName:"Message" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s WAFInvalidResourceException) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s WAFInvalidResourceException) GoString() string {
- return s.String()
- }
- func newErrorWAFInvalidResourceException(v protocol.ResponseMetadata) error {
- return &WAFInvalidResourceException{
- RespMetadata: v,
- }
- }
- // Code returns the exception type name.
- func (s *WAFInvalidResourceException) Code() string {
- return "WAFInvalidResourceException"
- }
- // Message returns the exception's message.
- func (s *WAFInvalidResourceException) Message() string {
- if s.Message_ != nil {
- return *s.Message_
- }
- return ""
- }
- // OrigErr always returns nil, satisfies awserr.Error interface.
- func (s *WAFInvalidResourceException) OrigErr() error {
- return nil
- }
- func (s *WAFInvalidResourceException) Error() string {
- return fmt.Sprintf("%s: %s", s.Code(), s.Message())
- }
- // Status code returns the HTTP status code for the request's response error.
- func (s *WAFInvalidResourceException) StatusCode() int {
- return s.RespMetadata.StatusCode
- }
- // RequestID returns the service's response RequestID for request.
- func (s *WAFInvalidResourceException) RequestID() string {
- return s.RespMetadata.RequestID
- }
- // WAF couldn’t perform the operation because you exceeded your resource limit.
- // For example, the maximum number of WebACL objects that you can create for
- // an Amazon Web Services account. For more information, see WAF quotas (https://docs.aws.amazon.com/waf/latest/developerguide/limits.html)
- // in the WAF Developer Guide.
- type WAFLimitsExceededException struct {
- _ struct{} `type:"structure"`
- RespMetadata protocol.ResponseMetadata `json:"-" xml:"-"`
- Message_ *string `locationName:"Message" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s WAFLimitsExceededException) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s WAFLimitsExceededException) GoString() string {
- return s.String()
- }
- func newErrorWAFLimitsExceededException(v protocol.ResponseMetadata) error {
- return &WAFLimitsExceededException{
- RespMetadata: v,
- }
- }
- // Code returns the exception type name.
- func (s *WAFLimitsExceededException) Code() string {
- return "WAFLimitsExceededException"
- }
- // Message returns the exception's message.
- func (s *WAFLimitsExceededException) Message() string {
- if s.Message_ != nil {
- return *s.Message_
- }
- return ""
- }
- // OrigErr always returns nil, satisfies awserr.Error interface.
- func (s *WAFLimitsExceededException) OrigErr() error {
- return nil
- }
- func (s *WAFLimitsExceededException) Error() string {
- return fmt.Sprintf("%s: %s", s.Code(), s.Message())
- }
- // Status code returns the HTTP status code for the request's response error.
- func (s *WAFLimitsExceededException) StatusCode() int {
- return s.RespMetadata.StatusCode
- }
- // RequestID returns the service's response RequestID for request.
- func (s *WAFLimitsExceededException) RequestID() string {
- return s.RespMetadata.RequestID
- }
- // The operation failed because you don't have the permissions that your logging
- // configuration requires. For information, see Logging web ACL traffic information
- // (https://docs.aws.amazon.com/waf/latest/developerguide/logging.html) in the
- // WAF Developer Guide.
- type WAFLogDestinationPermissionIssueException struct {
- _ struct{} `type:"structure"`
- RespMetadata protocol.ResponseMetadata `json:"-" xml:"-"`
- Message_ *string `locationName:"Message" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s WAFLogDestinationPermissionIssueException) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s WAFLogDestinationPermissionIssueException) GoString() string {
- return s.String()
- }
- func newErrorWAFLogDestinationPermissionIssueException(v protocol.ResponseMetadata) error {
- return &WAFLogDestinationPermissionIssueException{
- RespMetadata: v,
- }
- }
- // Code returns the exception type name.
- func (s *WAFLogDestinationPermissionIssueException) Code() string {
- return "WAFLogDestinationPermissionIssueException"
- }
- // Message returns the exception's message.
- func (s *WAFLogDestinationPermissionIssueException) Message() string {
- if s.Message_ != nil {
- return *s.Message_
- }
- return ""
- }
- // OrigErr always returns nil, satisfies awserr.Error interface.
- func (s *WAFLogDestinationPermissionIssueException) OrigErr() error {
- return nil
- }
- func (s *WAFLogDestinationPermissionIssueException) Error() string {
- return fmt.Sprintf("%s: %s", s.Code(), s.Message())
- }
- // Status code returns the HTTP status code for the request's response error.
- func (s *WAFLogDestinationPermissionIssueException) StatusCode() int {
- return s.RespMetadata.StatusCode
- }
- // RequestID returns the service's response RequestID for request.
- func (s *WAFLogDestinationPermissionIssueException) RequestID() string {
- return s.RespMetadata.RequestID
- }
- // WAF couldn’t perform the operation because your resource doesn't exist.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate.
- type WAFNonexistentItemException struct {
- _ struct{} `type:"structure"`
- RespMetadata protocol.ResponseMetadata `json:"-" xml:"-"`
- Message_ *string `locationName:"Message" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s WAFNonexistentItemException) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s WAFNonexistentItemException) GoString() string {
- return s.String()
- }
- func newErrorWAFNonexistentItemException(v protocol.ResponseMetadata) error {
- return &WAFNonexistentItemException{
- RespMetadata: v,
- }
- }
- // Code returns the exception type name.
- func (s *WAFNonexistentItemException) Code() string {
- return "WAFNonexistentItemException"
- }
- // Message returns the exception's message.
- func (s *WAFNonexistentItemException) Message() string {
- if s.Message_ != nil {
- return *s.Message_
- }
- return ""
- }
- // OrigErr always returns nil, satisfies awserr.Error interface.
- func (s *WAFNonexistentItemException) OrigErr() error {
- return nil
- }
- func (s *WAFNonexistentItemException) Error() string {
- return fmt.Sprintf("%s: %s", s.Code(), s.Message())
- }
- // Status code returns the HTTP status code for the request's response error.
- func (s *WAFNonexistentItemException) StatusCode() int {
- return s.RespMetadata.StatusCode
- }
- // RequestID returns the service's response RequestID for request.
- func (s *WAFNonexistentItemException) RequestID() string {
- return s.RespMetadata.RequestID
- }
- // WAF couldn’t save your changes because you tried to update or delete a
- // resource that has changed since you last retrieved it. Get the resource again,
- // make any changes you need to make to the new copy, and retry your operation.
- type WAFOptimisticLockException struct {
- _ struct{} `type:"structure"`
- RespMetadata protocol.ResponseMetadata `json:"-" xml:"-"`
- Message_ *string `locationName:"Message" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s WAFOptimisticLockException) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s WAFOptimisticLockException) GoString() string {
- return s.String()
- }
- func newErrorWAFOptimisticLockException(v protocol.ResponseMetadata) error {
- return &WAFOptimisticLockException{
- RespMetadata: v,
- }
- }
- // Code returns the exception type name.
- func (s *WAFOptimisticLockException) Code() string {
- return "WAFOptimisticLockException"
- }
- // Message returns the exception's message.
- func (s *WAFOptimisticLockException) Message() string {
- if s.Message_ != nil {
- return *s.Message_
- }
- return ""
- }
- // OrigErr always returns nil, satisfies awserr.Error interface.
- func (s *WAFOptimisticLockException) OrigErr() error {
- return nil
- }
- func (s *WAFOptimisticLockException) Error() string {
- return fmt.Sprintf("%s: %s", s.Code(), s.Message())
- }
- // Status code returns the HTTP status code for the request's response error.
- func (s *WAFOptimisticLockException) StatusCode() int {
- return s.RespMetadata.StatusCode
- }
- // RequestID returns the service's response RequestID for request.
- func (s *WAFOptimisticLockException) RequestID() string {
- return s.RespMetadata.RequestID
- }
- // WAF is not able to access the service linked role. This can be caused by
- // a previous PutLoggingConfiguration request, which can lock the service linked
- // role for about 20 seconds. Please try your request again. The service linked
- // role can also be locked by a previous DeleteServiceLinkedRole request, which
- // can lock the role for 15 minutes or more. If you recently made a call to
- // DeleteServiceLinkedRole, wait at least 15 minutes and try the request again.
- // If you receive this same exception again, you will have to wait additional
- // time until the role is unlocked.
- type WAFServiceLinkedRoleErrorException struct {
- _ struct{} `type:"structure"`
- RespMetadata protocol.ResponseMetadata `json:"-" xml:"-"`
- Message_ *string `locationName:"message" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s WAFServiceLinkedRoleErrorException) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s WAFServiceLinkedRoleErrorException) GoString() string {
- return s.String()
- }
- func newErrorWAFServiceLinkedRoleErrorException(v protocol.ResponseMetadata) error {
- return &WAFServiceLinkedRoleErrorException{
- RespMetadata: v,
- }
- }
- // Code returns the exception type name.
- func (s *WAFServiceLinkedRoleErrorException) Code() string {
- return "WAFServiceLinkedRoleErrorException"
- }
- // Message returns the exception's message.
- func (s *WAFServiceLinkedRoleErrorException) Message() string {
- if s.Message_ != nil {
- return *s.Message_
- }
- return ""
- }
- // OrigErr always returns nil, satisfies awserr.Error interface.
- func (s *WAFServiceLinkedRoleErrorException) OrigErr() error {
- return nil
- }
- func (s *WAFServiceLinkedRoleErrorException) Error() string {
- return fmt.Sprintf("%s: %s", s.Code(), s.Message())
- }
- // Status code returns the HTTP status code for the request's response error.
- func (s *WAFServiceLinkedRoleErrorException) StatusCode() int {
- return s.RespMetadata.StatusCode
- }
- // RequestID returns the service's response RequestID for request.
- func (s *WAFServiceLinkedRoleErrorException) RequestID() string {
- return s.RespMetadata.RequestID
- }
- // You tried to use a managed rule group that's available by subscription, but
- // you aren't subscribed to it yet.
- type WAFSubscriptionNotFoundException struct {
- _ struct{} `type:"structure"`
- RespMetadata protocol.ResponseMetadata `json:"-" xml:"-"`
- Message_ *string `locationName:"Message" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s WAFSubscriptionNotFoundException) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s WAFSubscriptionNotFoundException) GoString() string {
- return s.String()
- }
- func newErrorWAFSubscriptionNotFoundException(v protocol.ResponseMetadata) error {
- return &WAFSubscriptionNotFoundException{
- RespMetadata: v,
- }
- }
- // Code returns the exception type name.
- func (s *WAFSubscriptionNotFoundException) Code() string {
- return "WAFSubscriptionNotFoundException"
- }
- // Message returns the exception's message.
- func (s *WAFSubscriptionNotFoundException) Message() string {
- if s.Message_ != nil {
- return *s.Message_
- }
- return ""
- }
- // OrigErr always returns nil, satisfies awserr.Error interface.
- func (s *WAFSubscriptionNotFoundException) OrigErr() error {
- return nil
- }
- func (s *WAFSubscriptionNotFoundException) Error() string {
- return fmt.Sprintf("%s: %s", s.Code(), s.Message())
- }
- // Status code returns the HTTP status code for the request's response error.
- func (s *WAFSubscriptionNotFoundException) StatusCode() int {
- return s.RespMetadata.StatusCode
- }
- // RequestID returns the service's response RequestID for request.
- func (s *WAFSubscriptionNotFoundException) RequestID() string {
- return s.RespMetadata.RequestID
- }
- // An error occurred during the tagging operation. Retry your request.
- type WAFTagOperationException struct {
- _ struct{} `type:"structure"`
- RespMetadata protocol.ResponseMetadata `json:"-" xml:"-"`
- Message_ *string `locationName:"Message" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s WAFTagOperationException) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s WAFTagOperationException) GoString() string {
- return s.String()
- }
- func newErrorWAFTagOperationException(v protocol.ResponseMetadata) error {
- return &WAFTagOperationException{
- RespMetadata: v,
- }
- }
- // Code returns the exception type name.
- func (s *WAFTagOperationException) Code() string {
- return "WAFTagOperationException"
- }
- // Message returns the exception's message.
- func (s *WAFTagOperationException) Message() string {
- if s.Message_ != nil {
- return *s.Message_
- }
- return ""
- }
- // OrigErr always returns nil, satisfies awserr.Error interface.
- func (s *WAFTagOperationException) OrigErr() error {
- return nil
- }
- func (s *WAFTagOperationException) Error() string {
- return fmt.Sprintf("%s: %s", s.Code(), s.Message())
- }
- // Status code returns the HTTP status code for the request's response error.
- func (s *WAFTagOperationException) StatusCode() int {
- return s.RespMetadata.StatusCode
- }
- // RequestID returns the service's response RequestID for request.
- func (s *WAFTagOperationException) RequestID() string {
- return s.RespMetadata.RequestID
- }
- // WAF couldn’t perform your tagging operation because of an internal error.
- // Retry your request.
- type WAFTagOperationInternalErrorException struct {
- _ struct{} `type:"structure"`
- RespMetadata protocol.ResponseMetadata `json:"-" xml:"-"`
- Message_ *string `locationName:"Message" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s WAFTagOperationInternalErrorException) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s WAFTagOperationInternalErrorException) GoString() string {
- return s.String()
- }
- func newErrorWAFTagOperationInternalErrorException(v protocol.ResponseMetadata) error {
- return &WAFTagOperationInternalErrorException{
- RespMetadata: v,
- }
- }
- // Code returns the exception type name.
- func (s *WAFTagOperationInternalErrorException) Code() string {
- return "WAFTagOperationInternalErrorException"
- }
- // Message returns the exception's message.
- func (s *WAFTagOperationInternalErrorException) Message() string {
- if s.Message_ != nil {
- return *s.Message_
- }
- return ""
- }
- // OrigErr always returns nil, satisfies awserr.Error interface.
- func (s *WAFTagOperationInternalErrorException) OrigErr() error {
- return nil
- }
- func (s *WAFTagOperationInternalErrorException) Error() string {
- return fmt.Sprintf("%s: %s", s.Code(), s.Message())
- }
- // Status code returns the HTTP status code for the request's response error.
- func (s *WAFTagOperationInternalErrorException) StatusCode() int {
- return s.RespMetadata.StatusCode
- }
- // RequestID returns the service's response RequestID for request.
- func (s *WAFTagOperationInternalErrorException) RequestID() string {
- return s.RespMetadata.RequestID
- }
- // WAF couldn’t retrieve a resource that you specified for this operation.
- // If you've just created a resource that you're using in this operation, you
- // might just need to wait a few minutes. It can take from a few seconds to
- // a number of minutes for changes to propagate. Verify the resources that you
- // are specifying in your request parameters and then retry the operation.
- type WAFUnavailableEntityException struct {
- _ struct{} `type:"structure"`
- RespMetadata protocol.ResponseMetadata `json:"-" xml:"-"`
- Message_ *string `locationName:"Message" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s WAFUnavailableEntityException) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s WAFUnavailableEntityException) GoString() string {
- return s.String()
- }
- func newErrorWAFUnavailableEntityException(v protocol.ResponseMetadata) error {
- return &WAFUnavailableEntityException{
- RespMetadata: v,
- }
- }
- // Code returns the exception type name.
- func (s *WAFUnavailableEntityException) Code() string {
- return "WAFUnavailableEntityException"
- }
- // Message returns the exception's message.
- func (s *WAFUnavailableEntityException) Message() string {
- if s.Message_ != nil {
- return *s.Message_
- }
- return ""
- }
- // OrigErr always returns nil, satisfies awserr.Error interface.
- func (s *WAFUnavailableEntityException) OrigErr() error {
- return nil
- }
- func (s *WAFUnavailableEntityException) Error() string {
- return fmt.Sprintf("%s: %s", s.Code(), s.Message())
- }
- // Status code returns the HTTP status code for the request's response error.
- func (s *WAFUnavailableEntityException) StatusCode() int {
- return s.RespMetadata.StatusCode
- }
- // RequestID returns the service's response RequestID for request.
- func (s *WAFUnavailableEntityException) RequestID() string {
- return s.RespMetadata.RequestID
- }
- // A web ACL defines a collection of rules to use to inspect and control web
- // requests. Each rule has an action defined (allow, block, or count) for requests
- // that match the statement of the rule. In the web ACL, you assign a default
- // action to take (allow, block) for any request that does not match any of
- // the rules. The rules in a web ACL can be a combination of the types Rule,
- // RuleGroup, and managed rule group. You can associate a web ACL with one or
- // more Amazon Web Services resources to protect. The resources can be an Amazon
- // CloudFront distribution, an Amazon API Gateway REST API, an Application Load
- // Balancer, an AppSync GraphQL API, or an Amazon Cognito user pool.
- type WebACL struct {
- _ struct{} `type:"structure"`
- // The Amazon Resource Name (ARN) of the web ACL that you want to associate
- // with the resource.
- //
- // ARN is a required field
- ARN *string `min:"20" type:"string" required:"true"`
- // The web ACL capacity units (WCUs) currently being used by this web ACL.
- //
- // WAF uses WCUs to calculate and control the operating resources that are used
- // to run your rules, rule groups, and web ACLs. WAF calculates capacity differently
- // for each rule type, to reflect the relative cost of each rule. Simple rules
- // that cost little to run use fewer WCUs than more complex rules that use more
- // processing power. Rule group capacity is fixed at creation, which helps users
- // plan their web ACL WCU usage when they use a rule group. The WCU limit for
- // web ACLs is 1,500.
- Capacity *int64 `type:"long"`
- // Specifies how WAF should handle CAPTCHA evaluations for rules that don't
- // have their own CaptchaConfig settings. If you don't specify this, WAF uses
- // its default settings for CaptchaConfig.
- CaptchaConfig *CaptchaConfig `type:"structure"`
- // Specifies how WAF should handle challenge evaluations for rules that don't
- // have their own ChallengeConfig settings. If you don't specify this, WAF uses
- // its default settings for ChallengeConfig.
- ChallengeConfig *ChallengeConfig `type:"structure"`
- // A map of custom response keys and content bodies. When you create a rule
- // with a block action, you can send a custom response to the web request. You
- // define these for the web ACL, and then use them in the rules and default
- // actions that you define in the web ACL.
- //
- // For information about customizing web requests and responses, see Customizing
- // web requests and responses in WAF (https://docs.aws.amazon.com/waf/latest/developerguide/waf-custom-request-response.html)
- // in the WAF Developer Guide (https://docs.aws.amazon.com/waf/latest/developerguide/waf-chapter.html).
- //
- // For information about the limits on count and size for custom request and
- // response settings, see WAF quotas (https://docs.aws.amazon.com/waf/latest/developerguide/limits.html)
- // in the WAF Developer Guide (https://docs.aws.amazon.com/waf/latest/developerguide/waf-chapter.html).
- CustomResponseBodies map[string]*CustomResponseBody `min:"1" type:"map"`
- // The action to perform if none of the Rules contained in the WebACL match.
- //
- // DefaultAction is a required field
- DefaultAction *DefaultAction `type:"structure" required:"true"`
- // A description of the web ACL that helps with identification.
- Description *string `min:"1" type:"string"`
- // A unique identifier for the WebACL. This ID is returned in the responses
- // to create and list commands. You use this ID to do things like get, update,
- // and delete a WebACL.
- //
- // Id is a required field
- Id *string `min:"1" type:"string" required:"true"`
- // The label namespace prefix for this web ACL. All labels added by rules in
- // this web ACL have this prefix.
- //
- // * The syntax for the label namespace prefix for a web ACL is the following:
- // awswaf:<account ID>:webacl:<web ACL name>:
- //
- // * When a rule with a label matches a web request, WAF adds the fully qualified
- // label to the request. A fully qualified label is made up of the label
- // namespace from the rule group or web ACL where the rule is defined and
- // the label from the rule, separated by a colon: <label namespace>:<label
- // from rule>
- LabelNamespace *string `min:"1" type:"string"`
- // Indicates whether this web ACL is managed by Firewall Manager. If true, then
- // only Firewall Manager can delete the web ACL or any Firewall Manager rule
- // groups in the web ACL.
- ManagedByFirewallManager *bool `type:"boolean"`
- // The name of the web ACL. You cannot change the name of a web ACL after you
- // create it.
- //
- // Name is a required field
- Name *string `min:"1" type:"string" required:"true"`
- // The last set of rules for WAF to process in the web ACL. This is defined
- // in an Firewall Manager WAF policy and contains only rule group references.
- // You can't alter these. Any rules and rule groups that you define for the
- // web ACL are prioritized before these.
- //
- // In the Firewall Manager WAF policy, the Firewall Manager administrator can
- // define a set of rule groups to run first in the web ACL and a set of rule
- // groups to run last. Within each set, the administrator prioritizes the rule
- // groups, to determine their relative processing order.
- PostProcessFirewallManagerRuleGroups []*FirewallManagerRuleGroup `type:"list"`
- // The first set of rules for WAF to process in the web ACL. This is defined
- // in an Firewall Manager WAF policy and contains only rule group references.
- // You can't alter these. Any rules and rule groups that you define for the
- // web ACL are prioritized after these.
- //
- // In the Firewall Manager WAF policy, the Firewall Manager administrator can
- // define a set of rule groups to run first in the web ACL and a set of rule
- // groups to run last. Within each set, the administrator prioritizes the rule
- // groups, to determine their relative processing order.
- PreProcessFirewallManagerRuleGroups []*FirewallManagerRuleGroup `type:"list"`
- // The Rule statements used to identify the web requests that you want to allow,
- // block, or count. Each rule includes one top-level statement that WAF uses
- // to identify matching web requests, and parameters that govern how WAF handles
- // them.
- Rules []*Rule `type:"list"`
- // Specifies the domains that WAF should accept in a web request token. This
- // enables the use of tokens across multiple protected websites. When WAF provides
- // a token, it uses the domain of the Amazon Web Services resource that the
- // web ACL is protecting. If you don't specify a list of token domains, WAF
- // accepts tokens only for the domain of the protected resource. With a token
- // domain list, WAF accepts the resource's host domain plus all domains in the
- // token domain list, including their prefixed subdomains.
- TokenDomains []*string `min:"1" type:"list"`
- // Defines and enables Amazon CloudWatch metrics and web request sample collection.
- //
- // VisibilityConfig is a required field
- VisibilityConfig *VisibilityConfig `type:"structure" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s WebACL) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s WebACL) GoString() string {
- return s.String()
- }
- // SetARN sets the ARN field's value.
- func (s *WebACL) SetARN(v string) *WebACL {
- s.ARN = &v
- return s
- }
- // SetCapacity sets the Capacity field's value.
- func (s *WebACL) SetCapacity(v int64) *WebACL {
- s.Capacity = &v
- return s
- }
- // SetCaptchaConfig sets the CaptchaConfig field's value.
- func (s *WebACL) SetCaptchaConfig(v *CaptchaConfig) *WebACL {
- s.CaptchaConfig = v
- return s
- }
- // SetChallengeConfig sets the ChallengeConfig field's value.
- func (s *WebACL) SetChallengeConfig(v *ChallengeConfig) *WebACL {
- s.ChallengeConfig = v
- return s
- }
- // SetCustomResponseBodies sets the CustomResponseBodies field's value.
- func (s *WebACL) SetCustomResponseBodies(v map[string]*CustomResponseBody) *WebACL {
- s.CustomResponseBodies = v
- return s
- }
- // SetDefaultAction sets the DefaultAction field's value.
- func (s *WebACL) SetDefaultAction(v *DefaultAction) *WebACL {
- s.DefaultAction = v
- return s
- }
- // SetDescription sets the Description field's value.
- func (s *WebACL) SetDescription(v string) *WebACL {
- s.Description = &v
- return s
- }
- // SetId sets the Id field's value.
- func (s *WebACL) SetId(v string) *WebACL {
- s.Id = &v
- return s
- }
- // SetLabelNamespace sets the LabelNamespace field's value.
- func (s *WebACL) SetLabelNamespace(v string) *WebACL {
- s.LabelNamespace = &v
- return s
- }
- // SetManagedByFirewallManager sets the ManagedByFirewallManager field's value.
- func (s *WebACL) SetManagedByFirewallManager(v bool) *WebACL {
- s.ManagedByFirewallManager = &v
- return s
- }
- // SetName sets the Name field's value.
- func (s *WebACL) SetName(v string) *WebACL {
- s.Name = &v
- return s
- }
- // SetPostProcessFirewallManagerRuleGroups sets the PostProcessFirewallManagerRuleGroups field's value.
- func (s *WebACL) SetPostProcessFirewallManagerRuleGroups(v []*FirewallManagerRuleGroup) *WebACL {
- s.PostProcessFirewallManagerRuleGroups = v
- return s
- }
- // SetPreProcessFirewallManagerRuleGroups sets the PreProcessFirewallManagerRuleGroups field's value.
- func (s *WebACL) SetPreProcessFirewallManagerRuleGroups(v []*FirewallManagerRuleGroup) *WebACL {
- s.PreProcessFirewallManagerRuleGroups = v
- return s
- }
- // SetRules sets the Rules field's value.
- func (s *WebACL) SetRules(v []*Rule) *WebACL {
- s.Rules = v
- return s
- }
- // SetTokenDomains sets the TokenDomains field's value.
- func (s *WebACL) SetTokenDomains(v []*string) *WebACL {
- s.TokenDomains = v
- return s
- }
- // SetVisibilityConfig sets the VisibilityConfig field's value.
- func (s *WebACL) SetVisibilityConfig(v *VisibilityConfig) *WebACL {
- s.VisibilityConfig = v
- return s
- }
- // High-level information about a WebACL, returned by operations like create
- // and list. This provides information like the ID, that you can use to retrieve
- // and manage a WebACL, and the ARN, that you provide to operations like AssociateWebACL.
- type WebACLSummary struct {
- _ struct{} `type:"structure"`
- // The Amazon Resource Name (ARN) of the entity.
- ARN *string `min:"20" type:"string"`
- // A description of the web ACL that helps with identification.
- Description *string `min:"1" type:"string"`
- // The unique identifier for the web ACL. This ID is returned in the responses
- // to create and list commands. You provide it to operations like update and
- // delete.
- Id *string `min:"1" type:"string"`
- // A token used for optimistic locking. WAF returns a token to your get and
- // list requests, to mark the state of the entity at the time of the request.
- // To make changes to the entity associated with the token, you provide the
- // token to operations like update and delete. WAF uses the token to ensure
- // that no changes have been made to the entity since you last retrieved it.
- // If a change has been made, the update fails with a WAFOptimisticLockException.
- // If this happens, perform another get, and use the new token returned by that
- // operation.
- LockToken *string `min:"1" type:"string"`
- // The name of the web ACL. You cannot change the name of a web ACL after you
- // create it.
- Name *string `min:"1" type:"string"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s WebACLSummary) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s WebACLSummary) GoString() string {
- return s.String()
- }
- // SetARN sets the ARN field's value.
- func (s *WebACLSummary) SetARN(v string) *WebACLSummary {
- s.ARN = &v
- return s
- }
- // SetDescription sets the Description field's value.
- func (s *WebACLSummary) SetDescription(v string) *WebACLSummary {
- s.Description = &v
- return s
- }
- // SetId sets the Id field's value.
- func (s *WebACLSummary) SetId(v string) *WebACLSummary {
- s.Id = &v
- return s
- }
- // SetLockToken sets the LockToken field's value.
- func (s *WebACLSummary) SetLockToken(v string) *WebACLSummary {
- s.LockToken = &v
- return s
- }
- // SetName sets the Name field's value.
- func (s *WebACLSummary) SetName(v string) *WebACLSummary {
- s.Name = &v
- return s
- }
- // A rule statement that inspects for cross-site scripting (XSS) attacks. In
- // XSS attacks, the attacker uses vulnerabilities in a benign website as a vehicle
- // to inject malicious client-site scripts into other legitimate web browsers.
- type XssMatchStatement struct {
- _ struct{} `type:"structure"`
- // The part of the web request that you want WAF to inspect.
- //
- // FieldToMatch is a required field
- FieldToMatch *FieldToMatch `type:"structure" required:"true"`
- // Text transformations eliminate some of the unusual formatting that attackers
- // use in web requests in an effort to bypass detection. If you specify one
- // or more transformations in a rule statement, WAF performs all transformations
- // on the content of the request component identified by FieldToMatch, starting
- // from the lowest priority setting, before inspecting the content for a match.
- //
- // TextTransformations is a required field
- TextTransformations []*TextTransformation `min:"1" type:"list" required:"true"`
- }
- // String returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s XssMatchStatement) String() string {
- return awsutil.Prettify(s)
- }
- // GoString returns the string representation.
- //
- // API parameter values that are decorated as "sensitive" in the API will not
- // be included in the string output. The member name will be present, but the
- // value will be replaced with "sensitive".
- func (s XssMatchStatement) GoString() string {
- return s.String()
- }
- // Validate inspects the fields of the type to determine if they are valid.
- func (s *XssMatchStatement) Validate() error {
- invalidParams := request.ErrInvalidParams{Context: "XssMatchStatement"}
- if s.FieldToMatch == nil {
- invalidParams.Add(request.NewErrParamRequired("FieldToMatch"))
- }
- if s.TextTransformations == nil {
- invalidParams.Add(request.NewErrParamRequired("TextTransformations"))
- }
- if s.TextTransformations != nil && len(s.TextTransformations) < 1 {
- invalidParams.Add(request.NewErrParamMinLen("TextTransformations", 1))
- }
- if s.FieldToMatch != nil {
- if err := s.FieldToMatch.Validate(); err != nil {
- invalidParams.AddNested("FieldToMatch", err.(request.ErrInvalidParams))
- }
- }
- if s.TextTransformations != nil {
- for i, v := range s.TextTransformations {
- if v == nil {
- continue
- }
- if err := v.Validate(); err != nil {
- invalidParams.AddNested(fmt.Sprintf("%s[%v]", "TextTransformations", i), err.(request.ErrInvalidParams))
- }
- }
- }
- if invalidParams.Len() > 0 {
- return invalidParams
- }
- return nil
- }
- // SetFieldToMatch sets the FieldToMatch field's value.
- func (s *XssMatchStatement) SetFieldToMatch(v *FieldToMatch) *XssMatchStatement {
- s.FieldToMatch = v
- return s
- }
- // SetTextTransformations sets the TextTransformations field's value.
- func (s *XssMatchStatement) SetTextTransformations(v []*TextTransformation) *XssMatchStatement {
- s.TextTransformations = v
- return s
- }
- const (
- // ActionValueAllow is a ActionValue enum value
- ActionValueAllow = "ALLOW"
- // ActionValueBlock is a ActionValue enum value
- ActionValueBlock = "BLOCK"
- // ActionValueCount is a ActionValue enum value
- ActionValueCount = "COUNT"
- // ActionValueCaptcha is a ActionValue enum value
- ActionValueCaptcha = "CAPTCHA"
- // ActionValueChallenge is a ActionValue enum value
- ActionValueChallenge = "CHALLENGE"
- // ActionValueExcludedAsCount is a ActionValue enum value
- ActionValueExcludedAsCount = "EXCLUDED_AS_COUNT"
- )
- // ActionValue_Values returns all elements of the ActionValue enum
- func ActionValue_Values() []string {
- return []string{
- ActionValueAllow,
- ActionValueBlock,
- ActionValueCount,
- ActionValueCaptcha,
- ActionValueChallenge,
- ActionValueExcludedAsCount,
- }
- }
- const (
- // BodyParsingFallbackBehaviorMatch is a BodyParsingFallbackBehavior enum value
- BodyParsingFallbackBehaviorMatch = "MATCH"
- // BodyParsingFallbackBehaviorNoMatch is a BodyParsingFallbackBehavior enum value
- BodyParsingFallbackBehaviorNoMatch = "NO_MATCH"
- // BodyParsingFallbackBehaviorEvaluateAsString is a BodyParsingFallbackBehavior enum value
- BodyParsingFallbackBehaviorEvaluateAsString = "EVALUATE_AS_STRING"
- )
- // BodyParsingFallbackBehavior_Values returns all elements of the BodyParsingFallbackBehavior enum
- func BodyParsingFallbackBehavior_Values() []string {
- return []string{
- BodyParsingFallbackBehaviorMatch,
- BodyParsingFallbackBehaviorNoMatch,
- BodyParsingFallbackBehaviorEvaluateAsString,
- }
- }
- const (
- // ComparisonOperatorEq is a ComparisonOperator enum value
- ComparisonOperatorEq = "EQ"
- // ComparisonOperatorNe is a ComparisonOperator enum value
- ComparisonOperatorNe = "NE"
- // ComparisonOperatorLe is a ComparisonOperator enum value
- ComparisonOperatorLe = "LE"
- // ComparisonOperatorLt is a ComparisonOperator enum value
- ComparisonOperatorLt = "LT"
- // ComparisonOperatorGe is a ComparisonOperator enum value
- ComparisonOperatorGe = "GE"
- // ComparisonOperatorGt is a ComparisonOperator enum value
- ComparisonOperatorGt = "GT"
- )
- // ComparisonOperator_Values returns all elements of the ComparisonOperator enum
- func ComparisonOperator_Values() []string {
- return []string{
- ComparisonOperatorEq,
- ComparisonOperatorNe,
- ComparisonOperatorLe,
- ComparisonOperatorLt,
- ComparisonOperatorGe,
- ComparisonOperatorGt,
- }
- }
- const (
- // CountryCodeAf is a CountryCode enum value
- CountryCodeAf = "AF"
- // CountryCodeAx is a CountryCode enum value
- CountryCodeAx = "AX"
- // CountryCodeAl is a CountryCode enum value
- CountryCodeAl = "AL"
- // CountryCodeDz is a CountryCode enum value
- CountryCodeDz = "DZ"
- // CountryCodeAs is a CountryCode enum value
- CountryCodeAs = "AS"
- // CountryCodeAd is a CountryCode enum value
- CountryCodeAd = "AD"
- // CountryCodeAo is a CountryCode enum value
- CountryCodeAo = "AO"
- // CountryCodeAi is a CountryCode enum value
- CountryCodeAi = "AI"
- // CountryCodeAq is a CountryCode enum value
- CountryCodeAq = "AQ"
- // CountryCodeAg is a CountryCode enum value
- CountryCodeAg = "AG"
- // CountryCodeAr is a CountryCode enum value
- CountryCodeAr = "AR"
- // CountryCodeAm is a CountryCode enum value
- CountryCodeAm = "AM"
- // CountryCodeAw is a CountryCode enum value
- CountryCodeAw = "AW"
- // CountryCodeAu is a CountryCode enum value
- CountryCodeAu = "AU"
- // CountryCodeAt is a CountryCode enum value
- CountryCodeAt = "AT"
- // CountryCodeAz is a CountryCode enum value
- CountryCodeAz = "AZ"
- // CountryCodeBs is a CountryCode enum value
- CountryCodeBs = "BS"
- // CountryCodeBh is a CountryCode enum value
- CountryCodeBh = "BH"
- // CountryCodeBd is a CountryCode enum value
- CountryCodeBd = "BD"
- // CountryCodeBb is a CountryCode enum value
- CountryCodeBb = "BB"
- // CountryCodeBy is a CountryCode enum value
- CountryCodeBy = "BY"
- // CountryCodeBe is a CountryCode enum value
- CountryCodeBe = "BE"
- // CountryCodeBz is a CountryCode enum value
- CountryCodeBz = "BZ"
- // CountryCodeBj is a CountryCode enum value
- CountryCodeBj = "BJ"
- // CountryCodeBm is a CountryCode enum value
- CountryCodeBm = "BM"
- // CountryCodeBt is a CountryCode enum value
- CountryCodeBt = "BT"
- // CountryCodeBo is a CountryCode enum value
- CountryCodeBo = "BO"
- // CountryCodeBq is a CountryCode enum value
- CountryCodeBq = "BQ"
- // CountryCodeBa is a CountryCode enum value
- CountryCodeBa = "BA"
- // CountryCodeBw is a CountryCode enum value
- CountryCodeBw = "BW"
- // CountryCodeBv is a CountryCode enum value
- CountryCodeBv = "BV"
- // CountryCodeBr is a CountryCode enum value
- CountryCodeBr = "BR"
- // CountryCodeIo is a CountryCode enum value
- CountryCodeIo = "IO"
- // CountryCodeBn is a CountryCode enum value
- CountryCodeBn = "BN"
- // CountryCodeBg is a CountryCode enum value
- CountryCodeBg = "BG"
- // CountryCodeBf is a CountryCode enum value
- CountryCodeBf = "BF"
- // CountryCodeBi is a CountryCode enum value
- CountryCodeBi = "BI"
- // CountryCodeKh is a CountryCode enum value
- CountryCodeKh = "KH"
- // CountryCodeCm is a CountryCode enum value
- CountryCodeCm = "CM"
- // CountryCodeCa is a CountryCode enum value
- CountryCodeCa = "CA"
- // CountryCodeCv is a CountryCode enum value
- CountryCodeCv = "CV"
- // CountryCodeKy is a CountryCode enum value
- CountryCodeKy = "KY"
- // CountryCodeCf is a CountryCode enum value
- CountryCodeCf = "CF"
- // CountryCodeTd is a CountryCode enum value
- CountryCodeTd = "TD"
- // CountryCodeCl is a CountryCode enum value
- CountryCodeCl = "CL"
- // CountryCodeCn is a CountryCode enum value
- CountryCodeCn = "CN"
- // CountryCodeCx is a CountryCode enum value
- CountryCodeCx = "CX"
- // CountryCodeCc is a CountryCode enum value
- CountryCodeCc = "CC"
- // CountryCodeCo is a CountryCode enum value
- CountryCodeCo = "CO"
- // CountryCodeKm is a CountryCode enum value
- CountryCodeKm = "KM"
- // CountryCodeCg is a CountryCode enum value
- CountryCodeCg = "CG"
- // CountryCodeCd is a CountryCode enum value
- CountryCodeCd = "CD"
- // CountryCodeCk is a CountryCode enum value
- CountryCodeCk = "CK"
- // CountryCodeCr is a CountryCode enum value
- CountryCodeCr = "CR"
- // CountryCodeCi is a CountryCode enum value
- CountryCodeCi = "CI"
- // CountryCodeHr is a CountryCode enum value
- CountryCodeHr = "HR"
- // CountryCodeCu is a CountryCode enum value
- CountryCodeCu = "CU"
- // CountryCodeCw is a CountryCode enum value
- CountryCodeCw = "CW"
- // CountryCodeCy is a CountryCode enum value
- CountryCodeCy = "CY"
- // CountryCodeCz is a CountryCode enum value
- CountryCodeCz = "CZ"
- // CountryCodeDk is a CountryCode enum value
- CountryCodeDk = "DK"
- // CountryCodeDj is a CountryCode enum value
- CountryCodeDj = "DJ"
- // CountryCodeDm is a CountryCode enum value
- CountryCodeDm = "DM"
- // CountryCodeDo is a CountryCode enum value
- CountryCodeDo = "DO"
- // CountryCodeEc is a CountryCode enum value
- CountryCodeEc = "EC"
- // CountryCodeEg is a CountryCode enum value
- CountryCodeEg = "EG"
- // CountryCodeSv is a CountryCode enum value
- CountryCodeSv = "SV"
- // CountryCodeGq is a CountryCode enum value
- CountryCodeGq = "GQ"
- // CountryCodeEr is a CountryCode enum value
- CountryCodeEr = "ER"
- // CountryCodeEe is a CountryCode enum value
- CountryCodeEe = "EE"
- // CountryCodeEt is a CountryCode enum value
- CountryCodeEt = "ET"
- // CountryCodeFk is a CountryCode enum value
- CountryCodeFk = "FK"
- // CountryCodeFo is a CountryCode enum value
- CountryCodeFo = "FO"
- // CountryCodeFj is a CountryCode enum value
- CountryCodeFj = "FJ"
- // CountryCodeFi is a CountryCode enum value
- CountryCodeFi = "FI"
- // CountryCodeFr is a CountryCode enum value
- CountryCodeFr = "FR"
- // CountryCodeGf is a CountryCode enum value
- CountryCodeGf = "GF"
- // CountryCodePf is a CountryCode enum value
- CountryCodePf = "PF"
- // CountryCodeTf is a CountryCode enum value
- CountryCodeTf = "TF"
- // CountryCodeGa is a CountryCode enum value
- CountryCodeGa = "GA"
- // CountryCodeGm is a CountryCode enum value
- CountryCodeGm = "GM"
- // CountryCodeGe is a CountryCode enum value
- CountryCodeGe = "GE"
- // CountryCodeDe is a CountryCode enum value
- CountryCodeDe = "DE"
- // CountryCodeGh is a CountryCode enum value
- CountryCodeGh = "GH"
- // CountryCodeGi is a CountryCode enum value
- CountryCodeGi = "GI"
- // CountryCodeGr is a CountryCode enum value
- CountryCodeGr = "GR"
- // CountryCodeGl is a CountryCode enum value
- CountryCodeGl = "GL"
- // CountryCodeGd is a CountryCode enum value
- CountryCodeGd = "GD"
- // CountryCodeGp is a CountryCode enum value
- CountryCodeGp = "GP"
- // CountryCodeGu is a CountryCode enum value
- CountryCodeGu = "GU"
- // CountryCodeGt is a CountryCode enum value
- CountryCodeGt = "GT"
- // CountryCodeGg is a CountryCode enum value
- CountryCodeGg = "GG"
- // CountryCodeGn is a CountryCode enum value
- CountryCodeGn = "GN"
- // CountryCodeGw is a CountryCode enum value
- CountryCodeGw = "GW"
- // CountryCodeGy is a CountryCode enum value
- CountryCodeGy = "GY"
- // CountryCodeHt is a CountryCode enum value
- CountryCodeHt = "HT"
- // CountryCodeHm is a CountryCode enum value
- CountryCodeHm = "HM"
- // CountryCodeVa is a CountryCode enum value
- CountryCodeVa = "VA"
- // CountryCodeHn is a CountryCode enum value
- CountryCodeHn = "HN"
- // CountryCodeHk is a CountryCode enum value
- CountryCodeHk = "HK"
- // CountryCodeHu is a CountryCode enum value
- CountryCodeHu = "HU"
- // CountryCodeIs is a CountryCode enum value
- CountryCodeIs = "IS"
- // CountryCodeIn is a CountryCode enum value
- CountryCodeIn = "IN"
- // CountryCodeId is a CountryCode enum value
- CountryCodeId = "ID"
- // CountryCodeIr is a CountryCode enum value
- CountryCodeIr = "IR"
- // CountryCodeIq is a CountryCode enum value
- CountryCodeIq = "IQ"
- // CountryCodeIe is a CountryCode enum value
- CountryCodeIe = "IE"
- // CountryCodeIm is a CountryCode enum value
- CountryCodeIm = "IM"
- // CountryCodeIl is a CountryCode enum value
- CountryCodeIl = "IL"
- // CountryCodeIt is a CountryCode enum value
- CountryCodeIt = "IT"
- // CountryCodeJm is a CountryCode enum value
- CountryCodeJm = "JM"
- // CountryCodeJp is a CountryCode enum value
- CountryCodeJp = "JP"
- // CountryCodeJe is a CountryCode enum value
- CountryCodeJe = "JE"
- // CountryCodeJo is a CountryCode enum value
- CountryCodeJo = "JO"
- // CountryCodeKz is a CountryCode enum value
- CountryCodeKz = "KZ"
- // CountryCodeKe is a CountryCode enum value
- CountryCodeKe = "KE"
- // CountryCodeKi is a CountryCode enum value
- CountryCodeKi = "KI"
- // CountryCodeKp is a CountryCode enum value
- CountryCodeKp = "KP"
- // CountryCodeKr is a CountryCode enum value
- CountryCodeKr = "KR"
- // CountryCodeKw is a CountryCode enum value
- CountryCodeKw = "KW"
- // CountryCodeKg is a CountryCode enum value
- CountryCodeKg = "KG"
- // CountryCodeLa is a CountryCode enum value
- CountryCodeLa = "LA"
- // CountryCodeLv is a CountryCode enum value
- CountryCodeLv = "LV"
- // CountryCodeLb is a CountryCode enum value
- CountryCodeLb = "LB"
- // CountryCodeLs is a CountryCode enum value
- CountryCodeLs = "LS"
- // CountryCodeLr is a CountryCode enum value
- CountryCodeLr = "LR"
- // CountryCodeLy is a CountryCode enum value
- CountryCodeLy = "LY"
- // CountryCodeLi is a CountryCode enum value
- CountryCodeLi = "LI"
- // CountryCodeLt is a CountryCode enum value
- CountryCodeLt = "LT"
- // CountryCodeLu is a CountryCode enum value
- CountryCodeLu = "LU"
- // CountryCodeMo is a CountryCode enum value
- CountryCodeMo = "MO"
- // CountryCodeMk is a CountryCode enum value
- CountryCodeMk = "MK"
- // CountryCodeMg is a CountryCode enum value
- CountryCodeMg = "MG"
- // CountryCodeMw is a CountryCode enum value
- CountryCodeMw = "MW"
- // CountryCodeMy is a CountryCode enum value
- CountryCodeMy = "MY"
- // CountryCodeMv is a CountryCode enum value
- CountryCodeMv = "MV"
- // CountryCodeMl is a CountryCode enum value
- CountryCodeMl = "ML"
- // CountryCodeMt is a CountryCode enum value
- CountryCodeMt = "MT"
- // CountryCodeMh is a CountryCode enum value
- CountryCodeMh = "MH"
- // CountryCodeMq is a CountryCode enum value
- CountryCodeMq = "MQ"
- // CountryCodeMr is a CountryCode enum value
- CountryCodeMr = "MR"
- // CountryCodeMu is a CountryCode enum value
- CountryCodeMu = "MU"
- // CountryCodeYt is a CountryCode enum value
- CountryCodeYt = "YT"
- // CountryCodeMx is a CountryCode enum value
- CountryCodeMx = "MX"
- // CountryCodeFm is a CountryCode enum value
- CountryCodeFm = "FM"
- // CountryCodeMd is a CountryCode enum value
- CountryCodeMd = "MD"
- // CountryCodeMc is a CountryCode enum value
- CountryCodeMc = "MC"
- // CountryCodeMn is a CountryCode enum value
- CountryCodeMn = "MN"
- // CountryCodeMe is a CountryCode enum value
- CountryCodeMe = "ME"
- // CountryCodeMs is a CountryCode enum value
- CountryCodeMs = "MS"
- // CountryCodeMa is a CountryCode enum value
- CountryCodeMa = "MA"
- // CountryCodeMz is a CountryCode enum value
- CountryCodeMz = "MZ"
- // CountryCodeMm is a CountryCode enum value
- CountryCodeMm = "MM"
- // CountryCodeNa is a CountryCode enum value
- CountryCodeNa = "NA"
- // CountryCodeNr is a CountryCode enum value
- CountryCodeNr = "NR"
- // CountryCodeNp is a CountryCode enum value
- CountryCodeNp = "NP"
- // CountryCodeNl is a CountryCode enum value
- CountryCodeNl = "NL"
- // CountryCodeNc is a CountryCode enum value
- CountryCodeNc = "NC"
- // CountryCodeNz is a CountryCode enum value
- CountryCodeNz = "NZ"
- // CountryCodeNi is a CountryCode enum value
- CountryCodeNi = "NI"
- // CountryCodeNe is a CountryCode enum value
- CountryCodeNe = "NE"
- // CountryCodeNg is a CountryCode enum value
- CountryCodeNg = "NG"
- // CountryCodeNu is a CountryCode enum value
- CountryCodeNu = "NU"
- // CountryCodeNf is a CountryCode enum value
- CountryCodeNf = "NF"
- // CountryCodeMp is a CountryCode enum value
- CountryCodeMp = "MP"
- // CountryCodeNo is a CountryCode enum value
- CountryCodeNo = "NO"
- // CountryCodeOm is a CountryCode enum value
- CountryCodeOm = "OM"
- // CountryCodePk is a CountryCode enum value
- CountryCodePk = "PK"
- // CountryCodePw is a CountryCode enum value
- CountryCodePw = "PW"
- // CountryCodePs is a CountryCode enum value
- CountryCodePs = "PS"
- // CountryCodePa is a CountryCode enum value
- CountryCodePa = "PA"
- // CountryCodePg is a CountryCode enum value
- CountryCodePg = "PG"
- // CountryCodePy is a CountryCode enum value
- CountryCodePy = "PY"
- // CountryCodePe is a CountryCode enum value
- CountryCodePe = "PE"
- // CountryCodePh is a CountryCode enum value
- CountryCodePh = "PH"
- // CountryCodePn is a CountryCode enum value
- CountryCodePn = "PN"
- // CountryCodePl is a CountryCode enum value
- CountryCodePl = "PL"
- // CountryCodePt is a CountryCode enum value
- CountryCodePt = "PT"
- // CountryCodePr is a CountryCode enum value
- CountryCodePr = "PR"
- // CountryCodeQa is a CountryCode enum value
- CountryCodeQa = "QA"
- // CountryCodeRe is a CountryCode enum value
- CountryCodeRe = "RE"
- // CountryCodeRo is a CountryCode enum value
- CountryCodeRo = "RO"
- // CountryCodeRu is a CountryCode enum value
- CountryCodeRu = "RU"
- // CountryCodeRw is a CountryCode enum value
- CountryCodeRw = "RW"
- // CountryCodeBl is a CountryCode enum value
- CountryCodeBl = "BL"
- // CountryCodeSh is a CountryCode enum value
- CountryCodeSh = "SH"
- // CountryCodeKn is a CountryCode enum value
- CountryCodeKn = "KN"
- // CountryCodeLc is a CountryCode enum value
- CountryCodeLc = "LC"
- // CountryCodeMf is a CountryCode enum value
- CountryCodeMf = "MF"
- // CountryCodePm is a CountryCode enum value
- CountryCodePm = "PM"
- // CountryCodeVc is a CountryCode enum value
- CountryCodeVc = "VC"
- // CountryCodeWs is a CountryCode enum value
- CountryCodeWs = "WS"
- // CountryCodeSm is a CountryCode enum value
- CountryCodeSm = "SM"
- // CountryCodeSt is a CountryCode enum value
- CountryCodeSt = "ST"
- // CountryCodeSa is a CountryCode enum value
- CountryCodeSa = "SA"
- // CountryCodeSn is a CountryCode enum value
- CountryCodeSn = "SN"
- // CountryCodeRs is a CountryCode enum value
- CountryCodeRs = "RS"
- // CountryCodeSc is a CountryCode enum value
- CountryCodeSc = "SC"
- // CountryCodeSl is a CountryCode enum value
- CountryCodeSl = "SL"
- // CountryCodeSg is a CountryCode enum value
- CountryCodeSg = "SG"
- // CountryCodeSx is a CountryCode enum value
- CountryCodeSx = "SX"
- // CountryCodeSk is a CountryCode enum value
- CountryCodeSk = "SK"
- // CountryCodeSi is a CountryCode enum value
- CountryCodeSi = "SI"
- // CountryCodeSb is a CountryCode enum value
- CountryCodeSb = "SB"
- // CountryCodeSo is a CountryCode enum value
- CountryCodeSo = "SO"
- // CountryCodeZa is a CountryCode enum value
- CountryCodeZa = "ZA"
- // CountryCodeGs is a CountryCode enum value
- CountryCodeGs = "GS"
- // CountryCodeSs is a CountryCode enum value
- CountryCodeSs = "SS"
- // CountryCodeEs is a CountryCode enum value
- CountryCodeEs = "ES"
- // CountryCodeLk is a CountryCode enum value
- CountryCodeLk = "LK"
- // CountryCodeSd is a CountryCode enum value
- CountryCodeSd = "SD"
- // CountryCodeSr is a CountryCode enum value
- CountryCodeSr = "SR"
- // CountryCodeSj is a CountryCode enum value
- CountryCodeSj = "SJ"
- // CountryCodeSz is a CountryCode enum value
- CountryCodeSz = "SZ"
- // CountryCodeSe is a CountryCode enum value
- CountryCodeSe = "SE"
- // CountryCodeCh is a CountryCode enum value
- CountryCodeCh = "CH"
- // CountryCodeSy is a CountryCode enum value
- CountryCodeSy = "SY"
- // CountryCodeTw is a CountryCode enum value
- CountryCodeTw = "TW"
- // CountryCodeTj is a CountryCode enum value
- CountryCodeTj = "TJ"
- // CountryCodeTz is a CountryCode enum value
- CountryCodeTz = "TZ"
- // CountryCodeTh is a CountryCode enum value
- CountryCodeTh = "TH"
- // CountryCodeTl is a CountryCode enum value
- CountryCodeTl = "TL"
- // CountryCodeTg is a CountryCode enum value
- CountryCodeTg = "TG"
- // CountryCodeTk is a CountryCode enum value
- CountryCodeTk = "TK"
- // CountryCodeTo is a CountryCode enum value
- CountryCodeTo = "TO"
- // CountryCodeTt is a CountryCode enum value
- CountryCodeTt = "TT"
- // CountryCodeTn is a CountryCode enum value
- CountryCodeTn = "TN"
- // CountryCodeTr is a CountryCode enum value
- CountryCodeTr = "TR"
- // CountryCodeTm is a CountryCode enum value
- CountryCodeTm = "TM"
- // CountryCodeTc is a CountryCode enum value
- CountryCodeTc = "TC"
- // CountryCodeTv is a CountryCode enum value
- CountryCodeTv = "TV"
- // CountryCodeUg is a CountryCode enum value
- CountryCodeUg = "UG"
- // CountryCodeUa is a CountryCode enum value
- CountryCodeUa = "UA"
- // CountryCodeAe is a CountryCode enum value
- CountryCodeAe = "AE"
- // CountryCodeGb is a CountryCode enum value
- CountryCodeGb = "GB"
- // CountryCodeUs is a CountryCode enum value
- CountryCodeUs = "US"
- // CountryCodeUm is a CountryCode enum value
- CountryCodeUm = "UM"
- // CountryCodeUy is a CountryCode enum value
- CountryCodeUy = "UY"
- // CountryCodeUz is a CountryCode enum value
- CountryCodeUz = "UZ"
- // CountryCodeVu is a CountryCode enum value
- CountryCodeVu = "VU"
- // CountryCodeVe is a CountryCode enum value
- CountryCodeVe = "VE"
- // CountryCodeVn is a CountryCode enum value
- CountryCodeVn = "VN"
- // CountryCodeVg is a CountryCode enum value
- CountryCodeVg = "VG"
- // CountryCodeVi is a CountryCode enum value
- CountryCodeVi = "VI"
- // CountryCodeWf is a CountryCode enum value
- CountryCodeWf = "WF"
- // CountryCodeEh is a CountryCode enum value
- CountryCodeEh = "EH"
- // CountryCodeYe is a CountryCode enum value
- CountryCodeYe = "YE"
- // CountryCodeZm is a CountryCode enum value
- CountryCodeZm = "ZM"
- // CountryCodeZw is a CountryCode enum value
- CountryCodeZw = "ZW"
- // CountryCodeXk is a CountryCode enum value
- CountryCodeXk = "XK"
- )
- // CountryCode_Values returns all elements of the CountryCode enum
- func CountryCode_Values() []string {
- return []string{
- CountryCodeAf,
- CountryCodeAx,
- CountryCodeAl,
- CountryCodeDz,
- CountryCodeAs,
- CountryCodeAd,
- CountryCodeAo,
- CountryCodeAi,
- CountryCodeAq,
- CountryCodeAg,
- CountryCodeAr,
- CountryCodeAm,
- CountryCodeAw,
- CountryCodeAu,
- CountryCodeAt,
- CountryCodeAz,
- CountryCodeBs,
- CountryCodeBh,
- CountryCodeBd,
- CountryCodeBb,
- CountryCodeBy,
- CountryCodeBe,
- CountryCodeBz,
- CountryCodeBj,
- CountryCodeBm,
- CountryCodeBt,
- CountryCodeBo,
- CountryCodeBq,
- CountryCodeBa,
- CountryCodeBw,
- CountryCodeBv,
- CountryCodeBr,
- CountryCodeIo,
- CountryCodeBn,
- CountryCodeBg,
- CountryCodeBf,
- CountryCodeBi,
- CountryCodeKh,
- CountryCodeCm,
- CountryCodeCa,
- CountryCodeCv,
- CountryCodeKy,
- CountryCodeCf,
- CountryCodeTd,
- CountryCodeCl,
- CountryCodeCn,
- CountryCodeCx,
- CountryCodeCc,
- CountryCodeCo,
- CountryCodeKm,
- CountryCodeCg,
- CountryCodeCd,
- CountryCodeCk,
- CountryCodeCr,
- CountryCodeCi,
- CountryCodeHr,
- CountryCodeCu,
- CountryCodeCw,
- CountryCodeCy,
- CountryCodeCz,
- CountryCodeDk,
- CountryCodeDj,
- CountryCodeDm,
- CountryCodeDo,
- CountryCodeEc,
- CountryCodeEg,
- CountryCodeSv,
- CountryCodeGq,
- CountryCodeEr,
- CountryCodeEe,
- CountryCodeEt,
- CountryCodeFk,
- CountryCodeFo,
- CountryCodeFj,
- CountryCodeFi,
- CountryCodeFr,
- CountryCodeGf,
- CountryCodePf,
- CountryCodeTf,
- CountryCodeGa,
- CountryCodeGm,
- CountryCodeGe,
- CountryCodeDe,
- CountryCodeGh,
- CountryCodeGi,
- CountryCodeGr,
- CountryCodeGl,
- CountryCodeGd,
- CountryCodeGp,
- CountryCodeGu,
- CountryCodeGt,
- CountryCodeGg,
- CountryCodeGn,
- CountryCodeGw,
- CountryCodeGy,
- CountryCodeHt,
- CountryCodeHm,
- CountryCodeVa,
- CountryCodeHn,
- CountryCodeHk,
- CountryCodeHu,
- CountryCodeIs,
- CountryCodeIn,
- CountryCodeId,
- CountryCodeIr,
- CountryCodeIq,
- CountryCodeIe,
- CountryCodeIm,
- CountryCodeIl,
- CountryCodeIt,
- CountryCodeJm,
- CountryCodeJp,
- CountryCodeJe,
- CountryCodeJo,
- CountryCodeKz,
- CountryCodeKe,
- CountryCodeKi,
- CountryCodeKp,
- CountryCodeKr,
- CountryCodeKw,
- CountryCodeKg,
- CountryCodeLa,
- CountryCodeLv,
- CountryCodeLb,
- CountryCodeLs,
- CountryCodeLr,
- CountryCodeLy,
- CountryCodeLi,
- CountryCodeLt,
- CountryCodeLu,
- CountryCodeMo,
- CountryCodeMk,
- CountryCodeMg,
- CountryCodeMw,
- CountryCodeMy,
- CountryCodeMv,
- CountryCodeMl,
- CountryCodeMt,
- CountryCodeMh,
- CountryCodeMq,
- CountryCodeMr,
- CountryCodeMu,
- CountryCodeYt,
- CountryCodeMx,
- CountryCodeFm,
- CountryCodeMd,
- CountryCodeMc,
- CountryCodeMn,
- CountryCodeMe,
- CountryCodeMs,
- CountryCodeMa,
- CountryCodeMz,
- CountryCodeMm,
- CountryCodeNa,
- CountryCodeNr,
- CountryCodeNp,
- CountryCodeNl,
- CountryCodeNc,
- CountryCodeNz,
- CountryCodeNi,
- CountryCodeNe,
- CountryCodeNg,
- CountryCodeNu,
- CountryCodeNf,
- CountryCodeMp,
- CountryCodeNo,
- CountryCodeOm,
- CountryCodePk,
- CountryCodePw,
- CountryCodePs,
- CountryCodePa,
- CountryCodePg,
- CountryCodePy,
- CountryCodePe,
- CountryCodePh,
- CountryCodePn,
- CountryCodePl,
- CountryCodePt,
- CountryCodePr,
- CountryCodeQa,
- CountryCodeRe,
- CountryCodeRo,
- CountryCodeRu,
- CountryCodeRw,
- CountryCodeBl,
- CountryCodeSh,
- CountryCodeKn,
- CountryCodeLc,
- CountryCodeMf,
- CountryCodePm,
- CountryCodeVc,
- CountryCodeWs,
- CountryCodeSm,
- CountryCodeSt,
- CountryCodeSa,
- CountryCodeSn,
- CountryCodeRs,
- CountryCodeSc,
- CountryCodeSl,
- CountryCodeSg,
- CountryCodeSx,
- CountryCodeSk,
- CountryCodeSi,
- CountryCodeSb,
- CountryCodeSo,
- CountryCodeZa,
- CountryCodeGs,
- CountryCodeSs,
- CountryCodeEs,
- CountryCodeLk,
- CountryCodeSd,
- CountryCodeSr,
- CountryCodeSj,
- CountryCodeSz,
- CountryCodeSe,
- CountryCodeCh,
- CountryCodeSy,
- CountryCodeTw,
- CountryCodeTj,
- CountryCodeTz,
- CountryCodeTh,
- CountryCodeTl,
- CountryCodeTg,
- CountryCodeTk,
- CountryCodeTo,
- CountryCodeTt,
- CountryCodeTn,
- CountryCodeTr,
- CountryCodeTm,
- CountryCodeTc,
- CountryCodeTv,
- CountryCodeUg,
- CountryCodeUa,
- CountryCodeAe,
- CountryCodeGb,
- CountryCodeUs,
- CountryCodeUm,
- CountryCodeUy,
- CountryCodeUz,
- CountryCodeVu,
- CountryCodeVe,
- CountryCodeVn,
- CountryCodeVg,
- CountryCodeVi,
- CountryCodeWf,
- CountryCodeEh,
- CountryCodeYe,
- CountryCodeZm,
- CountryCodeZw,
- CountryCodeXk,
- }
- }
- const (
- // FailureReasonTokenMissing is a FailureReason enum value
- FailureReasonTokenMissing = "TOKEN_MISSING"
- // FailureReasonTokenExpired is a FailureReason enum value
- FailureReasonTokenExpired = "TOKEN_EXPIRED"
- // FailureReasonTokenInvalid is a FailureReason enum value
- FailureReasonTokenInvalid = "TOKEN_INVALID"
- // FailureReasonTokenDomainMismatch is a FailureReason enum value
- FailureReasonTokenDomainMismatch = "TOKEN_DOMAIN_MISMATCH"
- )
- // FailureReason_Values returns all elements of the FailureReason enum
- func FailureReason_Values() []string {
- return []string{
- FailureReasonTokenMissing,
- FailureReasonTokenExpired,
- FailureReasonTokenInvalid,
- FailureReasonTokenDomainMismatch,
- }
- }
- const (
- // FallbackBehaviorMatch is a FallbackBehavior enum value
- FallbackBehaviorMatch = "MATCH"
- // FallbackBehaviorNoMatch is a FallbackBehavior enum value
- FallbackBehaviorNoMatch = "NO_MATCH"
- )
- // FallbackBehavior_Values returns all elements of the FallbackBehavior enum
- func FallbackBehavior_Values() []string {
- return []string{
- FallbackBehaviorMatch,
- FallbackBehaviorNoMatch,
- }
- }
- const (
- // FilterBehaviorKeep is a FilterBehavior enum value
- FilterBehaviorKeep = "KEEP"
- // FilterBehaviorDrop is a FilterBehavior enum value
- FilterBehaviorDrop = "DROP"
- )
- // FilterBehavior_Values returns all elements of the FilterBehavior enum
- func FilterBehavior_Values() []string {
- return []string{
- FilterBehaviorKeep,
- FilterBehaviorDrop,
- }
- }
- const (
- // FilterRequirementMeetsAll is a FilterRequirement enum value
- FilterRequirementMeetsAll = "MEETS_ALL"
- // FilterRequirementMeetsAny is a FilterRequirement enum value
- FilterRequirementMeetsAny = "MEETS_ANY"
- )
- // FilterRequirement_Values returns all elements of the FilterRequirement enum
- func FilterRequirement_Values() []string {
- return []string{
- FilterRequirementMeetsAll,
- FilterRequirementMeetsAny,
- }
- }
- const (
- // ForwardedIPPositionFirst is a ForwardedIPPosition enum value
- ForwardedIPPositionFirst = "FIRST"
- // ForwardedIPPositionLast is a ForwardedIPPosition enum value
- ForwardedIPPositionLast = "LAST"
- // ForwardedIPPositionAny is a ForwardedIPPosition enum value
- ForwardedIPPositionAny = "ANY"
- )
- // ForwardedIPPosition_Values returns all elements of the ForwardedIPPosition enum
- func ForwardedIPPosition_Values() []string {
- return []string{
- ForwardedIPPositionFirst,
- ForwardedIPPositionLast,
- ForwardedIPPositionAny,
- }
- }
- const (
- // IPAddressVersionIpv4 is a IPAddressVersion enum value
- IPAddressVersionIpv4 = "IPV4"
- // IPAddressVersionIpv6 is a IPAddressVersion enum value
- IPAddressVersionIpv6 = "IPV6"
- )
- // IPAddressVersion_Values returns all elements of the IPAddressVersion enum
- func IPAddressVersion_Values() []string {
- return []string{
- IPAddressVersionIpv4,
- IPAddressVersionIpv6,
- }
- }
- const (
- // InspectionLevelCommon is a InspectionLevel enum value
- InspectionLevelCommon = "COMMON"
- // InspectionLevelTargeted is a InspectionLevel enum value
- InspectionLevelTargeted = "TARGETED"
- )
- // InspectionLevel_Values returns all elements of the InspectionLevel enum
- func InspectionLevel_Values() []string {
- return []string{
- InspectionLevelCommon,
- InspectionLevelTargeted,
- }
- }
- const (
- // JsonMatchScopeAll is a JsonMatchScope enum value
- JsonMatchScopeAll = "ALL"
- // JsonMatchScopeKey is a JsonMatchScope enum value
- JsonMatchScopeKey = "KEY"
- // JsonMatchScopeValue is a JsonMatchScope enum value
- JsonMatchScopeValue = "VALUE"
- )
- // JsonMatchScope_Values returns all elements of the JsonMatchScope enum
- func JsonMatchScope_Values() []string {
- return []string{
- JsonMatchScopeAll,
- JsonMatchScopeKey,
- JsonMatchScopeValue,
- }
- }
- const (
- // LabelMatchScopeLabel is a LabelMatchScope enum value
- LabelMatchScopeLabel = "LABEL"
- // LabelMatchScopeNamespace is a LabelMatchScope enum value
- LabelMatchScopeNamespace = "NAMESPACE"
- )
- // LabelMatchScope_Values returns all elements of the LabelMatchScope enum
- func LabelMatchScope_Values() []string {
- return []string{
- LabelMatchScopeLabel,
- LabelMatchScopeNamespace,
- }
- }
- const (
- // MapMatchScopeAll is a MapMatchScope enum value
- MapMatchScopeAll = "ALL"
- // MapMatchScopeKey is a MapMatchScope enum value
- MapMatchScopeKey = "KEY"
- // MapMatchScopeValue is a MapMatchScope enum value
- MapMatchScopeValue = "VALUE"
- )
- // MapMatchScope_Values returns all elements of the MapMatchScope enum
- func MapMatchScope_Values() []string {
- return []string{
- MapMatchScopeAll,
- MapMatchScopeKey,
- MapMatchScopeValue,
- }
- }
- const (
- // OversizeHandlingContinue is a OversizeHandling enum value
- OversizeHandlingContinue = "CONTINUE"
- // OversizeHandlingMatch is a OversizeHandling enum value
- OversizeHandlingMatch = "MATCH"
- // OversizeHandlingNoMatch is a OversizeHandling enum value
- OversizeHandlingNoMatch = "NO_MATCH"
- )
- // OversizeHandling_Values returns all elements of the OversizeHandling enum
- func OversizeHandling_Values() []string {
- return []string{
- OversizeHandlingContinue,
- OversizeHandlingMatch,
- OversizeHandlingNoMatch,
- }
- }
- const (
- // ParameterExceptionFieldWebAcl is a ParameterExceptionField enum value
- ParameterExceptionFieldWebAcl = "WEB_ACL"
- // ParameterExceptionFieldRuleGroup is a ParameterExceptionField enum value
- ParameterExceptionFieldRuleGroup = "RULE_GROUP"
- // ParameterExceptionFieldRegexPatternSet is a ParameterExceptionField enum value
- ParameterExceptionFieldRegexPatternSet = "REGEX_PATTERN_SET"
- // ParameterExceptionFieldIpSet is a ParameterExceptionField enum value
- ParameterExceptionFieldIpSet = "IP_SET"
- // ParameterExceptionFieldManagedRuleSet is a ParameterExceptionField enum value
- ParameterExceptionFieldManagedRuleSet = "MANAGED_RULE_SET"
- // ParameterExceptionFieldRule is a ParameterExceptionField enum value
- ParameterExceptionFieldRule = "RULE"
- // ParameterExceptionFieldExcludedRule is a ParameterExceptionField enum value
- ParameterExceptionFieldExcludedRule = "EXCLUDED_RULE"
- // ParameterExceptionFieldStatement is a ParameterExceptionField enum value
- ParameterExceptionFieldStatement = "STATEMENT"
- // ParameterExceptionFieldByteMatchStatement is a ParameterExceptionField enum value
- ParameterExceptionFieldByteMatchStatement = "BYTE_MATCH_STATEMENT"
- // ParameterExceptionFieldSqliMatchStatement is a ParameterExceptionField enum value
- ParameterExceptionFieldSqliMatchStatement = "SQLI_MATCH_STATEMENT"
- // ParameterExceptionFieldXssMatchStatement is a ParameterExceptionField enum value
- ParameterExceptionFieldXssMatchStatement = "XSS_MATCH_STATEMENT"
- // ParameterExceptionFieldSizeConstraintStatement is a ParameterExceptionField enum value
- ParameterExceptionFieldSizeConstraintStatement = "SIZE_CONSTRAINT_STATEMENT"
- // ParameterExceptionFieldGeoMatchStatement is a ParameterExceptionField enum value
- ParameterExceptionFieldGeoMatchStatement = "GEO_MATCH_STATEMENT"
- // ParameterExceptionFieldRateBasedStatement is a ParameterExceptionField enum value
- ParameterExceptionFieldRateBasedStatement = "RATE_BASED_STATEMENT"
- // ParameterExceptionFieldRuleGroupReferenceStatement is a ParameterExceptionField enum value
- ParameterExceptionFieldRuleGroupReferenceStatement = "RULE_GROUP_REFERENCE_STATEMENT"
- // ParameterExceptionFieldRegexPatternReferenceStatement is a ParameterExceptionField enum value
- ParameterExceptionFieldRegexPatternReferenceStatement = "REGEX_PATTERN_REFERENCE_STATEMENT"
- // ParameterExceptionFieldIpSetReferenceStatement is a ParameterExceptionField enum value
- ParameterExceptionFieldIpSetReferenceStatement = "IP_SET_REFERENCE_STATEMENT"
- // ParameterExceptionFieldManagedRuleSetStatement is a ParameterExceptionField enum value
- ParameterExceptionFieldManagedRuleSetStatement = "MANAGED_RULE_SET_STATEMENT"
- // ParameterExceptionFieldLabelMatchStatement is a ParameterExceptionField enum value
- ParameterExceptionFieldLabelMatchStatement = "LABEL_MATCH_STATEMENT"
- // ParameterExceptionFieldAndStatement is a ParameterExceptionField enum value
- ParameterExceptionFieldAndStatement = "AND_STATEMENT"
- // ParameterExceptionFieldOrStatement is a ParameterExceptionField enum value
- ParameterExceptionFieldOrStatement = "OR_STATEMENT"
- // ParameterExceptionFieldNotStatement is a ParameterExceptionField enum value
- ParameterExceptionFieldNotStatement = "NOT_STATEMENT"
- // ParameterExceptionFieldIpAddress is a ParameterExceptionField enum value
- ParameterExceptionFieldIpAddress = "IP_ADDRESS"
- // ParameterExceptionFieldIpAddressVersion is a ParameterExceptionField enum value
- ParameterExceptionFieldIpAddressVersion = "IP_ADDRESS_VERSION"
- // ParameterExceptionFieldFieldToMatch is a ParameterExceptionField enum value
- ParameterExceptionFieldFieldToMatch = "FIELD_TO_MATCH"
- // ParameterExceptionFieldTextTransformation is a ParameterExceptionField enum value
- ParameterExceptionFieldTextTransformation = "TEXT_TRANSFORMATION"
- // ParameterExceptionFieldSingleQueryArgument is a ParameterExceptionField enum value
- ParameterExceptionFieldSingleQueryArgument = "SINGLE_QUERY_ARGUMENT"
- // ParameterExceptionFieldSingleHeader is a ParameterExceptionField enum value
- ParameterExceptionFieldSingleHeader = "SINGLE_HEADER"
- // ParameterExceptionFieldDefaultAction is a ParameterExceptionField enum value
- ParameterExceptionFieldDefaultAction = "DEFAULT_ACTION"
- // ParameterExceptionFieldRuleAction is a ParameterExceptionField enum value
- ParameterExceptionFieldRuleAction = "RULE_ACTION"
- // ParameterExceptionFieldEntityLimit is a ParameterExceptionField enum value
- ParameterExceptionFieldEntityLimit = "ENTITY_LIMIT"
- // ParameterExceptionFieldOverrideAction is a ParameterExceptionField enum value
- ParameterExceptionFieldOverrideAction = "OVERRIDE_ACTION"
- // ParameterExceptionFieldScopeValue is a ParameterExceptionField enum value
- ParameterExceptionFieldScopeValue = "SCOPE_VALUE"
- // ParameterExceptionFieldResourceArn is a ParameterExceptionField enum value
- ParameterExceptionFieldResourceArn = "RESOURCE_ARN"
- // ParameterExceptionFieldResourceType is a ParameterExceptionField enum value
- ParameterExceptionFieldResourceType = "RESOURCE_TYPE"
- // ParameterExceptionFieldTags is a ParameterExceptionField enum value
- ParameterExceptionFieldTags = "TAGS"
- // ParameterExceptionFieldTagKeys is a ParameterExceptionField enum value
- ParameterExceptionFieldTagKeys = "TAG_KEYS"
- // ParameterExceptionFieldMetricName is a ParameterExceptionField enum value
- ParameterExceptionFieldMetricName = "METRIC_NAME"
- // ParameterExceptionFieldFirewallManagerStatement is a ParameterExceptionField enum value
- ParameterExceptionFieldFirewallManagerStatement = "FIREWALL_MANAGER_STATEMENT"
- // ParameterExceptionFieldFallbackBehavior is a ParameterExceptionField enum value
- ParameterExceptionFieldFallbackBehavior = "FALLBACK_BEHAVIOR"
- // ParameterExceptionFieldPosition is a ParameterExceptionField enum value
- ParameterExceptionFieldPosition = "POSITION"
- // ParameterExceptionFieldForwardedIpConfig is a ParameterExceptionField enum value
- ParameterExceptionFieldForwardedIpConfig = "FORWARDED_IP_CONFIG"
- // ParameterExceptionFieldIpSetForwardedIpConfig is a ParameterExceptionField enum value
- ParameterExceptionFieldIpSetForwardedIpConfig = "IP_SET_FORWARDED_IP_CONFIG"
- // ParameterExceptionFieldHeaderName is a ParameterExceptionField enum value
- ParameterExceptionFieldHeaderName = "HEADER_NAME"
- // ParameterExceptionFieldCustomRequestHandling is a ParameterExceptionField enum value
- ParameterExceptionFieldCustomRequestHandling = "CUSTOM_REQUEST_HANDLING"
- // ParameterExceptionFieldResponseContentType is a ParameterExceptionField enum value
- ParameterExceptionFieldResponseContentType = "RESPONSE_CONTENT_TYPE"
- // ParameterExceptionFieldCustomResponse is a ParameterExceptionField enum value
- ParameterExceptionFieldCustomResponse = "CUSTOM_RESPONSE"
- // ParameterExceptionFieldCustomResponseBody is a ParameterExceptionField enum value
- ParameterExceptionFieldCustomResponseBody = "CUSTOM_RESPONSE_BODY"
- // ParameterExceptionFieldJsonMatchPattern is a ParameterExceptionField enum value
- ParameterExceptionFieldJsonMatchPattern = "JSON_MATCH_PATTERN"
- // ParameterExceptionFieldJsonMatchScope is a ParameterExceptionField enum value
- ParameterExceptionFieldJsonMatchScope = "JSON_MATCH_SCOPE"
- // ParameterExceptionFieldBodyParsingFallbackBehavior is a ParameterExceptionField enum value
- ParameterExceptionFieldBodyParsingFallbackBehavior = "BODY_PARSING_FALLBACK_BEHAVIOR"
- // ParameterExceptionFieldLoggingFilter is a ParameterExceptionField enum value
- ParameterExceptionFieldLoggingFilter = "LOGGING_FILTER"
- // ParameterExceptionFieldFilterCondition is a ParameterExceptionField enum value
- ParameterExceptionFieldFilterCondition = "FILTER_CONDITION"
- // ParameterExceptionFieldExpireTimestamp is a ParameterExceptionField enum value
- ParameterExceptionFieldExpireTimestamp = "EXPIRE_TIMESTAMP"
- // ParameterExceptionFieldChangePropagationStatus is a ParameterExceptionField enum value
- ParameterExceptionFieldChangePropagationStatus = "CHANGE_PROPAGATION_STATUS"
- // ParameterExceptionFieldAssociableResource is a ParameterExceptionField enum value
- ParameterExceptionFieldAssociableResource = "ASSOCIABLE_RESOURCE"
- // ParameterExceptionFieldLogDestination is a ParameterExceptionField enum value
- ParameterExceptionFieldLogDestination = "LOG_DESTINATION"
- // ParameterExceptionFieldManagedRuleGroupConfig is a ParameterExceptionField enum value
- ParameterExceptionFieldManagedRuleGroupConfig = "MANAGED_RULE_GROUP_CONFIG"
- // ParameterExceptionFieldPayloadType is a ParameterExceptionField enum value
- ParameterExceptionFieldPayloadType = "PAYLOAD_TYPE"
- // ParameterExceptionFieldHeaderMatchPattern is a ParameterExceptionField enum value
- ParameterExceptionFieldHeaderMatchPattern = "HEADER_MATCH_PATTERN"
- // ParameterExceptionFieldCookieMatchPattern is a ParameterExceptionField enum value
- ParameterExceptionFieldCookieMatchPattern = "COOKIE_MATCH_PATTERN"
- // ParameterExceptionFieldMapMatchScope is a ParameterExceptionField enum value
- ParameterExceptionFieldMapMatchScope = "MAP_MATCH_SCOPE"
- // ParameterExceptionFieldOversizeHandling is a ParameterExceptionField enum value
- ParameterExceptionFieldOversizeHandling = "OVERSIZE_HANDLING"
- // ParameterExceptionFieldChallengeConfig is a ParameterExceptionField enum value
- ParameterExceptionFieldChallengeConfig = "CHALLENGE_CONFIG"
- // ParameterExceptionFieldTokenDomain is a ParameterExceptionField enum value
- ParameterExceptionFieldTokenDomain = "TOKEN_DOMAIN"
- )
- // ParameterExceptionField_Values returns all elements of the ParameterExceptionField enum
- func ParameterExceptionField_Values() []string {
- return []string{
- ParameterExceptionFieldWebAcl,
- ParameterExceptionFieldRuleGroup,
- ParameterExceptionFieldRegexPatternSet,
- ParameterExceptionFieldIpSet,
- ParameterExceptionFieldManagedRuleSet,
- ParameterExceptionFieldRule,
- ParameterExceptionFieldExcludedRule,
- ParameterExceptionFieldStatement,
- ParameterExceptionFieldByteMatchStatement,
- ParameterExceptionFieldSqliMatchStatement,
- ParameterExceptionFieldXssMatchStatement,
- ParameterExceptionFieldSizeConstraintStatement,
- ParameterExceptionFieldGeoMatchStatement,
- ParameterExceptionFieldRateBasedStatement,
- ParameterExceptionFieldRuleGroupReferenceStatement,
- ParameterExceptionFieldRegexPatternReferenceStatement,
- ParameterExceptionFieldIpSetReferenceStatement,
- ParameterExceptionFieldManagedRuleSetStatement,
- ParameterExceptionFieldLabelMatchStatement,
- ParameterExceptionFieldAndStatement,
- ParameterExceptionFieldOrStatement,
- ParameterExceptionFieldNotStatement,
- ParameterExceptionFieldIpAddress,
- ParameterExceptionFieldIpAddressVersion,
- ParameterExceptionFieldFieldToMatch,
- ParameterExceptionFieldTextTransformation,
- ParameterExceptionFieldSingleQueryArgument,
- ParameterExceptionFieldSingleHeader,
- ParameterExceptionFieldDefaultAction,
- ParameterExceptionFieldRuleAction,
- ParameterExceptionFieldEntityLimit,
- ParameterExceptionFieldOverrideAction,
- ParameterExceptionFieldScopeValue,
- ParameterExceptionFieldResourceArn,
- ParameterExceptionFieldResourceType,
- ParameterExceptionFieldTags,
- ParameterExceptionFieldTagKeys,
- ParameterExceptionFieldMetricName,
- ParameterExceptionFieldFirewallManagerStatement,
- ParameterExceptionFieldFallbackBehavior,
- ParameterExceptionFieldPosition,
- ParameterExceptionFieldForwardedIpConfig,
- ParameterExceptionFieldIpSetForwardedIpConfig,
- ParameterExceptionFieldHeaderName,
- ParameterExceptionFieldCustomRequestHandling,
- ParameterExceptionFieldResponseContentType,
- ParameterExceptionFieldCustomResponse,
- ParameterExceptionFieldCustomResponseBody,
- ParameterExceptionFieldJsonMatchPattern,
- ParameterExceptionFieldJsonMatchScope,
- ParameterExceptionFieldBodyParsingFallbackBehavior,
- ParameterExceptionFieldLoggingFilter,
- ParameterExceptionFieldFilterCondition,
- ParameterExceptionFieldExpireTimestamp,
- ParameterExceptionFieldChangePropagationStatus,
- ParameterExceptionFieldAssociableResource,
- ParameterExceptionFieldLogDestination,
- ParameterExceptionFieldManagedRuleGroupConfig,
- ParameterExceptionFieldPayloadType,
- ParameterExceptionFieldHeaderMatchPattern,
- ParameterExceptionFieldCookieMatchPattern,
- ParameterExceptionFieldMapMatchScope,
- ParameterExceptionFieldOversizeHandling,
- ParameterExceptionFieldChallengeConfig,
- ParameterExceptionFieldTokenDomain,
- }
- }
- const (
- // PayloadTypeJson is a PayloadType enum value
- PayloadTypeJson = "JSON"
- // PayloadTypeFormEncoded is a PayloadType enum value
- PayloadTypeFormEncoded = "FORM_ENCODED"
- )
- // PayloadType_Values returns all elements of the PayloadType enum
- func PayloadType_Values() []string {
- return []string{
- PayloadTypeJson,
- PayloadTypeFormEncoded,
- }
- }
- const (
- // PlatformIos is a Platform enum value
- PlatformIos = "IOS"
- // PlatformAndroid is a Platform enum value
- PlatformAndroid = "ANDROID"
- )
- // Platform_Values returns all elements of the Platform enum
- func Platform_Values() []string {
- return []string{
- PlatformIos,
- PlatformAndroid,
- }
- }
- const (
- // PositionalConstraintExactly is a PositionalConstraint enum value
- PositionalConstraintExactly = "EXACTLY"
- // PositionalConstraintStartsWith is a PositionalConstraint enum value
- PositionalConstraintStartsWith = "STARTS_WITH"
- // PositionalConstraintEndsWith is a PositionalConstraint enum value
- PositionalConstraintEndsWith = "ENDS_WITH"
- // PositionalConstraintContains is a PositionalConstraint enum value
- PositionalConstraintContains = "CONTAINS"
- // PositionalConstraintContainsWord is a PositionalConstraint enum value
- PositionalConstraintContainsWord = "CONTAINS_WORD"
- )
- // PositionalConstraint_Values returns all elements of the PositionalConstraint enum
- func PositionalConstraint_Values() []string {
- return []string{
- PositionalConstraintExactly,
- PositionalConstraintStartsWith,
- PositionalConstraintEndsWith,
- PositionalConstraintContains,
- PositionalConstraintContainsWord,
- }
- }
- const (
- // RateBasedStatementAggregateKeyTypeIp is a RateBasedStatementAggregateKeyType enum value
- RateBasedStatementAggregateKeyTypeIp = "IP"
- // RateBasedStatementAggregateKeyTypeForwardedIp is a RateBasedStatementAggregateKeyType enum value
- RateBasedStatementAggregateKeyTypeForwardedIp = "FORWARDED_IP"
- )
- // RateBasedStatementAggregateKeyType_Values returns all elements of the RateBasedStatementAggregateKeyType enum
- func RateBasedStatementAggregateKeyType_Values() []string {
- return []string{
- RateBasedStatementAggregateKeyTypeIp,
- RateBasedStatementAggregateKeyTypeForwardedIp,
- }
- }
- const (
- // ResourceTypeApplicationLoadBalancer is a ResourceType enum value
- ResourceTypeApplicationLoadBalancer = "APPLICATION_LOAD_BALANCER"
- // ResourceTypeApiGateway is a ResourceType enum value
- ResourceTypeApiGateway = "API_GATEWAY"
- // ResourceTypeAppsync is a ResourceType enum value
- ResourceTypeAppsync = "APPSYNC"
- // ResourceTypeCognitoUserPool is a ResourceType enum value
- ResourceTypeCognitoUserPool = "COGNITO_USER_POOL"
- )
- // ResourceType_Values returns all elements of the ResourceType enum
- func ResourceType_Values() []string {
- return []string{
- ResourceTypeApplicationLoadBalancer,
- ResourceTypeApiGateway,
- ResourceTypeAppsync,
- ResourceTypeCognitoUserPool,
- }
- }
- const (
- // ResponseContentTypeTextPlain is a ResponseContentType enum value
- ResponseContentTypeTextPlain = "TEXT_PLAIN"
- // ResponseContentTypeTextHtml is a ResponseContentType enum value
- ResponseContentTypeTextHtml = "TEXT_HTML"
- // ResponseContentTypeApplicationJson is a ResponseContentType enum value
- ResponseContentTypeApplicationJson = "APPLICATION_JSON"
- )
- // ResponseContentType_Values returns all elements of the ResponseContentType enum
- func ResponseContentType_Values() []string {
- return []string{
- ResponseContentTypeTextPlain,
- ResponseContentTypeTextHtml,
- ResponseContentTypeApplicationJson,
- }
- }
- const (
- // ScopeCloudfront is a Scope enum value
- ScopeCloudfront = "CLOUDFRONT"
- // ScopeRegional is a Scope enum value
- ScopeRegional = "REGIONAL"
- )
- // Scope_Values returns all elements of the Scope enum
- func Scope_Values() []string {
- return []string{
- ScopeCloudfront,
- ScopeRegional,
- }
- }
- const (
- // SensitivityLevelLow is a SensitivityLevel enum value
- SensitivityLevelLow = "LOW"
- // SensitivityLevelHigh is a SensitivityLevel enum value
- SensitivityLevelHigh = "HIGH"
- )
- // SensitivityLevel_Values returns all elements of the SensitivityLevel enum
- func SensitivityLevel_Values() []string {
- return []string{
- SensitivityLevelLow,
- SensitivityLevelHigh,
- }
- }
- const (
- // TextTransformationTypeNone is a TextTransformationType enum value
- TextTransformationTypeNone = "NONE"
- // TextTransformationTypeCompressWhiteSpace is a TextTransformationType enum value
- TextTransformationTypeCompressWhiteSpace = "COMPRESS_WHITE_SPACE"
- // TextTransformationTypeHtmlEntityDecode is a TextTransformationType enum value
- TextTransformationTypeHtmlEntityDecode = "HTML_ENTITY_DECODE"
- // TextTransformationTypeLowercase is a TextTransformationType enum value
- TextTransformationTypeLowercase = "LOWERCASE"
- // TextTransformationTypeCmdLine is a TextTransformationType enum value
- TextTransformationTypeCmdLine = "CMD_LINE"
- // TextTransformationTypeUrlDecode is a TextTransformationType enum value
- TextTransformationTypeUrlDecode = "URL_DECODE"
- // TextTransformationTypeBase64Decode is a TextTransformationType enum value
- TextTransformationTypeBase64Decode = "BASE64_DECODE"
- // TextTransformationTypeHexDecode is a TextTransformationType enum value
- TextTransformationTypeHexDecode = "HEX_DECODE"
- // TextTransformationTypeMd5 is a TextTransformationType enum value
- TextTransformationTypeMd5 = "MD5"
- // TextTransformationTypeReplaceComments is a TextTransformationType enum value
- TextTransformationTypeReplaceComments = "REPLACE_COMMENTS"
- // TextTransformationTypeEscapeSeqDecode is a TextTransformationType enum value
- TextTransformationTypeEscapeSeqDecode = "ESCAPE_SEQ_DECODE"
- // TextTransformationTypeSqlHexDecode is a TextTransformationType enum value
- TextTransformationTypeSqlHexDecode = "SQL_HEX_DECODE"
- // TextTransformationTypeCssDecode is a TextTransformationType enum value
- TextTransformationTypeCssDecode = "CSS_DECODE"
- // TextTransformationTypeJsDecode is a TextTransformationType enum value
- TextTransformationTypeJsDecode = "JS_DECODE"
- // TextTransformationTypeNormalizePath is a TextTransformationType enum value
- TextTransformationTypeNormalizePath = "NORMALIZE_PATH"
- // TextTransformationTypeNormalizePathWin is a TextTransformationType enum value
- TextTransformationTypeNormalizePathWin = "NORMALIZE_PATH_WIN"
- // TextTransformationTypeRemoveNulls is a TextTransformationType enum value
- TextTransformationTypeRemoveNulls = "REMOVE_NULLS"
- // TextTransformationTypeReplaceNulls is a TextTransformationType enum value
- TextTransformationTypeReplaceNulls = "REPLACE_NULLS"
- // TextTransformationTypeBase64DecodeExt is a TextTransformationType enum value
- TextTransformationTypeBase64DecodeExt = "BASE64_DECODE_EXT"
- // TextTransformationTypeUrlDecodeUni is a TextTransformationType enum value
- TextTransformationTypeUrlDecodeUni = "URL_DECODE_UNI"
- // TextTransformationTypeUtf8ToUnicode is a TextTransformationType enum value
- TextTransformationTypeUtf8ToUnicode = "UTF8_TO_UNICODE"
- )
- // TextTransformationType_Values returns all elements of the TextTransformationType enum
- func TextTransformationType_Values() []string {
- return []string{
- TextTransformationTypeNone,
- TextTransformationTypeCompressWhiteSpace,
- TextTransformationTypeHtmlEntityDecode,
- TextTransformationTypeLowercase,
- TextTransformationTypeCmdLine,
- TextTransformationTypeUrlDecode,
- TextTransformationTypeBase64Decode,
- TextTransformationTypeHexDecode,
- TextTransformationTypeMd5,
- TextTransformationTypeReplaceComments,
- TextTransformationTypeEscapeSeqDecode,
- TextTransformationTypeSqlHexDecode,
- TextTransformationTypeCssDecode,
- TextTransformationTypeJsDecode,
- TextTransformationTypeNormalizePath,
- TextTransformationTypeNormalizePathWin,
- TextTransformationTypeRemoveNulls,
- TextTransformationTypeReplaceNulls,
- TextTransformationTypeBase64DecodeExt,
- TextTransformationTypeUrlDecodeUni,
- TextTransformationTypeUtf8ToUnicode,
- }
- }
|