diff --git a/README.md b/README.md index 52c79aa..be7f939 100644 --- a/README.md +++ b/README.md @@ -41,7 +41,7 @@ Improvements from the minimal implementation: - [x] Groth16 - [ ] multiple optimizations - [x] wasm proof generation -- [ ] wasm proof verification +- [x] wasm proof verification ## WASM usage Ongoing experimentation with go-snark compiled to wasm: https://github.com/arnaucube/go-snark/tree/master/wasm diff --git a/go-snark-cli b/go-snark-cli index a0dc726..6266a0e 100755 Binary files a/go-snark-cli and b/go-snark-cli differ diff --git a/wasm/README.md b/wasm/README.md index a95ee81..5fdae15 100644 --- a/wasm/README.md +++ b/wasm/README.md @@ -12,15 +12,7 @@ Add the file `wasm_exec.js` in the directory: cp "$(go env GOROOT)/misc/wasm/wasm_exec.js" . ``` -Call the library from javascript: -```js -let r = generateProofs( - JSON.stringify(circuit), - JSON.stringify(setup), - JSON.stringify(px), - JSON.stringify(inputs), -); -``` +To see the usage from javascript, check `index.js` file. Run the http server that allows to load the `.wasm` file: ``` diff --git a/wasm/go-snark-wasm-wrapper.go b/wasm/go-snark-wasm-wrapper.go index 8f96c03..44cc8b9 100644 --- a/wasm/go-snark-wasm-wrapper.go +++ b/wasm/go-snark-wasm-wrapper.go @@ -2,6 +2,7 @@ package main import ( "encoding/json" + "math/big" "syscall/js" "github.com/arnaucube/go-snark" @@ -11,15 +12,14 @@ import ( func main() { c := make(chan struct{}, 0) - println("WASM Go Initialized") - // register functions registerCallbacks() <-c } func registerCallbacks() { js.Global().Set("generateProofs", js.FuncOf(generateProofs)) + js.Global().Set("verifyProofs", js.FuncOf(verifyProofs)) } func generateProofs(this js.Value, i []js.Value) interface{} { @@ -89,3 +89,56 @@ func generateProofs(this js.Value, i []js.Value) interface{} { println("proofJson", string(proofJson)) return js.ValueOf(string(proofJson)) } + +func verifyProofs(this js.Value, i []js.Value) interface{} { + var circuitStr utils.CircuitString + err := json.Unmarshal([]byte(i[0].String()), &circuitStr) + if err != nil { + println(i[0].String()) + println("error parsing circuit from stringified json") + } + circuit, err := utils.CircuitFromString(circuitStr) + if err != nil { + println("error " + err.Error()) + } + + var setupStr utils.SetupString + println(i[1].String()) + err = json.Unmarshal([]byte(i[1].String()), &setupStr) + if err != nil { + println("error parsing setup from stringified json") + } + setup, err := utils.SetupFromString(setupStr) + if err != nil { + println("error " + err.Error()) + } + + var proofStr utils.ProofString + err = json.Unmarshal([]byte(i[2].String()), &proofStr) + if err != nil { + println(i[0].String()) + println("error parsing proof from stringified json") + } + proof, err := utils.ProofFromString(proofStr) + if err != nil { + println("error " + err.Error()) + } + + var publicInputs []*big.Int + err = json.Unmarshal([]byte(i[3].String()), &publicInputs) + if err != nil { + println(i[0].String()) + println("error parsing publicInputs from stringified json") + } + + verified := snark.VerifyProof(circuit, setup, proof, publicInputs, false) + if err != nil { + println("error verifiyng proof", err) + } + verifiedJson, err := json.Marshal(verified) + if err != nil { + println("error marshal verified to json", err) + } + println("verifiedJson", string(verifiedJson)) + return js.ValueOf(string(verifiedJson)) +} diff --git a/wasm/go-snark.wasm b/wasm/go-snark.wasm index da3d99b..9b56560 100755 Binary files a/wasm/go-snark.wasm and b/wasm/go-snark.wasm differ diff --git a/wasm/index.html b/wasm/index.html index a2a05b0..fd9dec3 100644 --- a/wasm/index.html +++ b/wasm/index.html @@ -14,6 +14,7 @@ + diff --git a/wasm/index.js b/wasm/index.js index f6c53ad..f7ad94b 100644 --- a/wasm/index.js +++ b/wasm/index.js @@ -4,7 +4,7 @@ const inputs = { Public: [35] }; const circuit = {"NVars":8,"NPublic":1,"NSignals":8,"PrivateInputs":["s0"],"PublicInputs":["s1"],"Signals":["one","s1","s0","s2","s3","s4","s5","out"],"Witness":null,"Constraints":[{"Op":"in","V1":"","V2":"","Out":"s1","Literal":"","PrivateInputs":null,"PublicInputs":null},{"Op":"in","V1":"","V2":"","Out":"s0","Literal":"","PrivateInputs":null,"PublicInputs":null},{"Op":"*","V1":"s0","V2":"s0","Out":"s2","Literal":"s2=s0*s0","PrivateInputs":null,"PublicInputs":null},{"Op":"*","V1":"s2","V2":"s0","Out":"s3","Literal":"s3=s2*s0","PrivateInputs":null,"PublicInputs":null},{"Op":"+","V1":"s3","V2":"s0","Out":"s4","Literal":"s4=s3+s0","PrivateInputs":null,"PublicInputs":null},{"Op":"+","V1":"s4","V2":"5","Out":"s5","Literal":"s5=s4+5","PrivateInputs":null,"PublicInputs":null},{"Op":"*","V1":"s5","V2":"1","Out":"s1","Literal":"equals(s1, s5): s1==s5 * 1","PrivateInputs":null,"PublicInputs":null},{"Op":"*","V1":"s1","V2":"1","Out":"s5","Literal":"equals(s1, s5): s5==s1 * 1","PrivateInputs":null,"PublicInputs":null},{"Op":"*","V1":"1","V2":"1","Out":"out","Literal":"out=1*1","PrivateInputs":null,"PublicInputs":null}],"R1CS":{"A":[["0","0","1","0","0","0","0","0"],["0","0","0","1","0","0","0","0"],["0","0","1","0","1","0","0","0"],["5","0","0","0","0","1","0","0"],["0","0","0","0","0","0","1","0"],["0","1","0","0","0","0","0","0"],["1","0","0","0","0","0","0","0"]],"B":[["0","0","1","0","0","0","0","0"],["0","0","1","0","0","0","0","0"],["1","0","0","0","0","0","0","0"],["1","0","0","0","0","0","0","0"],["1","0","0","0","0","0","0","0"],["1","0","0","0","0","0","0","0"],["1","0","0","0","0","0","0","0"]],"C":[["0","0","0","1","0","0","0","0"],["0","0","0","0","1","0","0","0"],["0","0","0","0","0","1","0","0"],["0","0","0","0","0","0","1","0"],["0","1","0","0","0","0","0","0"],["0","0","0","0","0","0","1","0"],["0","0","0","0","0","0","0","1"]]}}; -const setup = {"G1T":[["1","2","1"],["8575626224492235243533435898870260119236182852755699776978120368205667538606","2933778004839945360708728461901701604240919170877802540225719058474943204185","14628407423970810052294035912959698878927568860529167454163145630753491346427"],["18454957249961765489874831143286810511802306936296106357052197603472405277808","14658598166757382612557279292328692545566235650603047825701555710007467968709","18743794331641832114797690908608583132817489068876568575418379674338076077152"],["21778929521183110696789571313120683179752980563944219483463209390502538057800","2528698833815927698858200632574058746151199880545906220333922530665914312707","11933651651917555824999286820884803109137989997564081355855419917633674907766"],["5868208941349652345991404474752004628673500171098375079813427360273763635110","4284425519100680585302546062413495108310084471914010039544675362412786357903","20855229450103488850737836984908832945536177391089017094645459600772220658951"],["4366609998121355855474770129521248316882619029481987263339453513161919905653","18298206710554424242507715874337041639276079224224730722942797746591756250445","16051413175194189400019433204401104613509047319378027692377533602189186706802"],["5562634954901756481593494808776353761597049590911471091472523505210262266727","12649655064245384312579564660310524704608549713434941098550348481751678809134","13984478717807435647122191548027513516160161817430214800786892756493218414971"]],"G2T":null,"Pk":{"A":[["3902249879669161685512196293707054296727897468441172006734746540263778553009","1412420343759862572462926710363248860501703957554240820750807290571502311144","2249384855013937606258946183561629730580974664070374232309925751321457797021"],["3672480284051680542894417049925388865827639715367049694712178524178731645964","9098759319134087749764453777394234473406765824846519121657831226777813367370","15847483628798852497403624280680555243278418074552427350491277493620402852072"],["8667940891217799053282198735975652557520306843886415105939223075964668940834","11330984995652525184893899066114448756634522714492323539374533687583277348631","625396587507860914735840906883949854703160873630715906208203334883717878338"],["20235412408226679010836378340147112502013802058967017699689541293967994324512","567103332961643161247245877785375903891230873735627361457299697585244915075","1151849661714113776777051252266554080382698677599845276176540258251530952008"],["18884862772625215814645550891644927806456099652538370545682545649828872986769","1821214577629122285941690503772493383066521187352267386988336689284973402326","14075767416621074498646558215666976946884509768218809290046389590531851678622"],["2064205892869746570295557779630845841334682836848164949125091516144188555394","8362981746921290522960209031534908689070067715253578609695290670282161683817","2247795621323238473214502926269611611188190175931708004849502949263061715912"],["15867800775858987237737660350267641821146505778108412900024793692303698156899","19839735904441315572183873044166316423387844788671113800937964457697715260543","20168617069726248283717765968123357521244926068960351034800445727260608671678"],["0","0","0"]],"B":[[["9483094236534571682182215462961592031579314049158704697972560045449446567638","486112660838316223177748786518939847366271439618152288625040264257357426731"],["12266911373462797403356949289869688674616283163894063621502828046398800398990","3625449786130562055782693578953089136657506988233259053631964025118092862171"],["15249686478347725239938794659776734142747194422653250871845918222489394476896","6467514790149158411685465571133818451456638139868469970886010113397057037535"]],[["0","0"],["0","0"],["0","0"]],[["16753416069771008653712116339962547821414102953385167341248554666274850970245","16118874239370436120147740628680683076832649657752412781619133194763429379033"],["3149380595622531259488908287713230897004518449768011926193160828838373540194","8791376655175439798878441328619596126799692276835763783312434315313685697711"],["4289162649938302409091338730339675062777051314154772713587852602265702296552","7139858067499443509715881857837775267281277306153960899098964485804376451319"]],[["0","0"],["0","0"],["0","0"]],[["0","0"],["0","0"],["0","0"]],[["0","0"],["0","0"],["0","0"]],[["0","0"],["0","0"],["0","0"]],[["0","0"],["0","0"],["0","0"]]],"C":[["0","0","0"],["452504233378077817421968372660828589248698511439695455859043803559863591434","20826818777646605158149830417858056568282979556550187874142948518530696776984","67545357455853110589965963691805962207911030549432877146476426820215669727"],["0","0","0"],["11087299143339322336104611109891901658196905570246178436223058120756029528013","13685807830217349551175376595976929403791341825355825502139500994224288776706","4921018326168436622835711189416351331946749307879728990511118302700312269456"],["19485643034175792178163108308322831106551793166123376188997671532704626016286","8257555791460598147194530503219137838105743159797937344504121423927511009186","18871836212014309199393626697291742966563504245822135643779397484003797436241"],["12921730572562050303554019236265467542655278905712200757270209481282431790316","8208126625363317974792168365775321152784413447574757011891347365799548201213","3775789595468249016693882675250633755953697785196461896396982719703830317045"],["16195765156345604139107669377209950888548585705571396636497096729498949233170","1281604834426446577818956823469728825089410370063844028682015790480247829541","19784447533783054714509015931266797723649053010543929673386763496789005847986"],["13336063360013921202751962386495342381037024526391575259398727659497975016895","2311776974020160443662080559190122011056081857579221775104191259973825887398","14013821065681001708529278505398680203069117693772650572755005836524284565038"]],"Kp":[["10270730247583150317421024803636151412895787234437446685559087014676440855987","12249851880888656578078622206546923979404909447349636059234479487873193580771","10352337369310715938914117514146547576575547826976630346494647467027527590048"],["11066072207629347583054784906182857391171651652156992876241847737075684673673","15130197654433921798452524887549977089966102739803647627184910043787576369109","17404674219138545094322570249013835104062402974316800589564811399933801049566"],["14864877624562224543748795743017769853704420620207337057079481448225975068348","5647231549965996402431809106932126957464132955295625098876436065029216269990","19226714859966000734891539434729678790259773119147462579990179805929312680238"],["915153020049126432079408605236732995388440856037161363071817205571243737235","12380433681885418895798615221021123404215332052624367444540116708118951519091","14809461715434073130054423358195040108349605009027452238217040333853993050609"],["8080317507962347752127857415457811344496627249373431450951670980704479887743","12252496533585894721881099822144217497700079135495782729963394798181595722392","2640494132351364858419969802954450113747991539748690648581958385273028321144"],["179713073641823824219986510731835531938973508646552874675605030471026670558","12134967632609417960726493758555514770951054767097024642948691666219896428666","7566271664452686639594491222671436316074104604486690426607237321070412773699"],["19221875851590621754775366415180467766082972794923104443791021972717461138283","1551882011953603674531753787399615108390177538817489289393790465249027454042","20451622561509076366681138907563405683082731600124850963791374820458886504439"],["2865373458352327862754300705076500112993949566179073375852339656279828872122","3807886606343637681106167390610416073673852686850736266803909387591982945884","15528839551827723412313389353214350066287203905648911871971951458958942598466"]],"Ap":[["8774769459846963005194211989541771650746540578516450980934429155387835676362","18124217260784212186962796832680177754188694608529864771067390565827387179055","2950915544052867175471419779727028472561230950002201308460172720403773626114"],["12608117810102351826723441084042895115880387424526993707317712339687456974831","5421302585671950984291255785653748446611562143106327411629522947432113705424","11414326579769919500149438676554751973208842490344351795247231414313202315490"],["5148800542584889714511009208176880305285940531885462428115121315957465406555","9895304148524924445216012800179791656340897879481578222479988615516837537918","16484695189291856449279886693979507303782401833361607899445671999680389574703"],["14842984023612426331673397297597710887115312262280874155205200392557434733","11566988958660987741585887320406815382349200306071598157833382553761383202895","12724758205891038354068958409121343272805384738610358452282032185672153281922"],["16148986286344558481619138671217758322621206389763204069739438434122138559895","12310242321059446781347322826096220475849384867948961176102995162419647659020","505361307032094078882564155690582364305146243509951875520722283479787292676"],["8535305474940673933865765204818301946104278374977304970658756896006370871951","20748088137647310365446524304013688743735530319573002353360195284726753570803","1762445709757217394983149820371328979604644379316103448091311419947991704185"],["17413587275445021980401455255188250191575142271882622317832940732360687497906","13225040494123533363798870113355021168769729359974069264263265367006225692292","6805174651166353793479430700999955221680577728441130211221603706442048363667"],["0","0","0"]],"Bp":[["1446662920161440386158926658337095442845234501040816434926666938514262098740","18966597146105477920735776744754667981781800492082938910861161145002470984060","6012093054045648561406536241021127307997186153471949390832850083203146646108"],["0","0","0"],["10628384530419813069205954601806945930384066395423071480814760143006452112706","8497870536327557859589108645477201961797670370461730065048426466843396066984","3329957171489780291015578410680526097411251026152446362865497158699197050721"],["0","0","0"],["0","0","0"],["0","0","0"],["0","0","0"],["0","0","0"]],"Cp":[["0","0","0"],["14920937290018562140937570572571014056740753097581661083979403204920891658742","21811944937123197403496283148929198873872814082189005486385636700926879750209","14030127762547581758363998031388878597541430681512379343404666475535743344213"],["0","0","0"],["14379022274305279958710903963796316757770071705869530789581703036458746794769","8176961606726118499175853632676212724311900262565784774028821367476981532535","18879248469583037953966988520679747897380998353147295504451659232634221564201"],["6584394006531031864174152183024256880195715748537433666438135393819019975805","16854040579713775108259443344736799730509709441800073406825213745815991711957","13036416345582014951910903015636059420209703549614657491825167945925831684745"],["8261450318962865312319211141023670887023587939978621014889639986777028730759","13638915109503325597390872023164493151164961051469741054244917796222754105456","11536475689379687031152013881207096151854000458510681147360024206311605875869"],["14363802979506866314489413398127831635994328164726272702554010888130325735353","5390561501337839036731461825395126872871195524442771420517483943593676920855","8260230864537213129923324620217992505641853737814833592113891317968785398695"],["21099758545013781800989242554510167577611563271614464838950229743685435084911","8124530770006885515246883500407472402497205176823674986451771394572328608635","67223368706533218675640727387047699211751832696016695819563918855507975507"]],"Z":["720","21888242871839275222246405745257275088548364400416034343698204186575808493853","1624","21888242871839275222246405745257275088548364400416034343698204186575808494882","175","21888242871839275222246405745257275088548364400416034343698204186575808495596","1"]},"Vk":{"Vka":[["",""],["",""],["",""]],"Vkb":["","",""],"Vkc":[["",""],["",""],["",""]],"IC":null,"G1Kbg":["","",""],"G2Kbg":[["",""],["",""],["",""]],"G2Kg":[["",""],["",""],["",""]],"Vkz":[["",""],["",""],["",""]]}}; +const setup = {"G1T":[["1","2","1"],["9060122645382620703912131576596541626275459709528189228377806057487579608777","18552187397697551333331725893031797322982741119378938051419279530432019342188","3919832823776698517503991563314380964772509805496866335136766014655653885039"],["3431942732352420155072012305772200032351558289434666812664907450194303325062","4439599953252627470375533428625515591130196040383855535852348208030559853883","14380560303832201195398083235300299176047912901985399685682202109326154017836"],["11822380047681984103313692560743268302859438330661504781058076964635828163545","8488512494309293936137843888199752117254316665196510892680599422501820645496","207004353051063893639356651228375382867476477156537867899604336306721551467"],["13369149528075388664712802073899096107708041573561715823114105693815630697378","6525621151123618360901435612882281583875709999978828932272129288831466827866","11600385445429612519884793603235271263938097080983698348010928146803302198747"],["18825387175693767583147722806260279460154004788869566944381085627780183542321","21871358166487926120169952009258732520451507028508675117536950592602704070959","8338796029255778027872921751274765153551503228218840224193616009381870863859"],["5295089009059580756220007472162113933002275383891633808559131232316008899814","19161554621761663329748638078311007921708756009709737212648552680361792208166","5748093032442185061964190665446005439031320403353312848790332588256670922610"]],"G2T":null,"Pk":{"A":[["7174206590592787125297180086710023841226950848202094190665117479806387137883","17652025361381698291522443621361023414364698651922621167014090353827449887602","14028631817708334859212193494275677331425051891495047854336610288692893108523"],["9496211367937653129316339857607539932181489693017062849205858418506655217336","20715527976204177150125765369524021558336699683501368910122162008825354750707","18144702909222194940950017253098692203736826433930172591650227400416842046007"],["8901446074764075762317322178403715419786041734956949277497403600806655756999","1819546472752206525532345074946787072722754628056662237144167000020486136261","14011785723394611426263152521847748432413809948263682161626132238732409292156"],["3034322623472011366874310663122511445017897586814784238936130126083833342572","6000716018565206962631571744863084388195912679008915160547676552399144597222","19633356630741448377199281317268311013507848842507369122202461483618915252791"],["20400767842971485002755729001425862955157807736474954458535675697195868062157","2480339942144794994541179826591189975358952742940180047516155221987544649543","2930359521139331505426168469282155091733507964960079037721723057334380754832"],["15972800874658679764040929017147984737594922899793665982077616144811369187929","516092169688554124376657658423277195353489015172032409759529165262089173843","13393164579642250179301818522896567463002539684064419152857556777450792232485"],["7989664273119626379441761463603280444548957021816315575283452454158546653123","20521624009984172416112083757509334497384073164090293573602315991532953084126","9329559313197536002444990345118096485080888784374316889753587882609581324708"],["0","0","0"]],"B":[[["5815369437987100634609339902385421223315394731609221757034488448935919995916","8252390417041598259382486298194659712618888866174524769037422532689839477658"],["11533402706690712823766541428715411632779261603093597859161664756122531183237","18627526051178474362533706672805205430694267650356820844522468576441067526839"],["5816946121727103786752704946398277271179139419210154515139785707542532543515","8711188252952341899050651095594182425912023670301734838624741835772060675923"]],[["0","0"],["0","0"],["0","0"]],[["2401819658168185492503821857831354652027009144511160692800080431942811642954","17887968592994135563790051067012399327748486012642292105318763562719151670738"],["10194497249847711690662078608111424117717077813588311699424143534915621933145","5716972360720872183753890650316537039876875814617422375421303585710342314972"],["11191630595691625428764822244945047324117541309730980482204081246404577903244","16929614368553665442422134772689491903010833430956238740001557474030061052047"]],[["0","0"],["0","0"],["0","0"]],[["0","0"],["0","0"],["0","0"]],[["0","0"],["0","0"],["0","0"]],[["0","0"],["0","0"],["0","0"]],[["0","0"],["0","0"],["0","0"]]],"C":[["0","0","0"],["7228767935399026124377674569835023996471124047376499986588322759520287376643","15756846338035180234637287638488767247805098673677786920524329717482129350970","3171690559257254733468070394886500227122785515732964450380707782252885192427"],["0","0","0"],["502178371863112877214246669105223240671288387004954562104561474318626628358","14281071509372702160411194231620580091825555855821393182911135574049788049250","13353222991856667158413464713971759235844487491950350135168816332124546071957"],["75830204847830990594144479386955887505479373961361960992122468551082617598","3620989002593745206918814452932530954989678696591623917474446342425092995497","19666444163225247314242064702527779043250121130484727356466142911949111935438"],["9031012234534022136483008989682930453160625935900206563086229260562901425140","12167734924968472048363017594858894873922981749643702767142838456901122279618","8866186995178277587293519284886147013162202661113424681959849037110579430954"],["7043614674423437565815457189316920937598596386585351081257639723526445294622","13997282284798872174173623407608412755589971684761434109988488309457350594322","5432033042341951323916232775494378178055280220023620917623070336881935188880"],["12540326078906727737977942384837308648589691803986711969888425075942125072515","20336215384724265398926866877489490981908331512379622833283546888430087905285","404381112074483703365120720382997575432300588716855073754573083326810107046"]],"Kp":[["16397731635341061441600048298332877379485321359782651940831453466888087726793","11990389239268162965738393253423986038495575862450766744339565491500894056998","4740202064294228054891894739816778666936733392862283378796889148289715470140"],["12461454013977576960065191252419221404197669361166610130734464986277253862324","6094388489154805073749746895410983103386493705580804449661063285519872192451","8359105801841182960739325087251631077342120727282223771432006229153914968890"],["18457408708429046146629326609802671028103942264210002426725236753035516623906","18545849575159982833013987628873581232936077783444232057806007948855054399625","618749639505772405889754631206429697176812030971262513731033712304234874418"],["4557458278801119067353358785306376592356924433404696901104306174394808584856","11727755992040510811991308532742640403357849878113224062166958735310365336821","11800005947420536690266944520797644308314964571308722589856008342003550438733"],["11045237773515655252238230722838602454216253865679283403883451102008737954322","20459622981394974501639705422311715443696149891014332262191264185012934820835","16704662814308768799348611138107904053331354994353926431672416749019955129354"],["7666109966547297455059674915442404837637115579036115598101747754770977557225","18512894982168636908918309706134992141627978876560796851949223013303115195291","19823718127687878306247084559452726410731057102132140941746905033465319714386"],["8923951353178846455449386767499183969139412662946660616673044124895919749553","16080607484400595699269809548351227229290499524769502164338935861202252610358","18003572383917501082652709867467294420820997768712604413771466196940372695536"],["9493928075603028079979385952295263213757105981181830620659024601654311048961","16033649245701154034094927637666840087702550265715865953269493122798725310441","18838535899918008331143704820589722656209350313166306272877060336239646296736"]],"Ap":[["17310202984743469784106570115659758169564348235060651103821167200155783660918","2045857096388329417446474612981991173436096054584464753685233111783909278185","149258049057629035002740575667943995604773593033407664490503911393137939724"],["12308502803380963717917299028665830285655931293373977919528546972772611201893","3573390545894811605897775284829227309141780937281562397893394071295330341327","15759991386309921105345895393351664441629404398194632678619406374074747343461"],["17919191091012506920817750996376310406088010875380023766754475715290868397752","14992232101897933477049912622215992904072719270431233853990556171603707415082","16608227653666428681518809275951539253294049396546857477308378296354036796892"],["6953747325129672696717463838122915047815275353293122028433963608181201863882","6419581023792778112762192572596350211310078278044361882053378885462079944238","12832145701739198674116310242269406968876180979244356882610581968128858520762"],["9432254756736523110034404783484840768780306500787008606137624450505554520435","6238049349920776714077150877453703226567604544525725602435764552740388147061","16206787146740222307434915485322443350901391864542964549250937609221279435121"],["20621184205232877805958633205452087718190994896343873812870546221433686913613","12856359198128666430171274778842157543041689589723182023473900388392058929606","11582912053018919500379507725486489329655937241224344538021607590326180677358"],["16677528246129312709240739617646314258879663219575692781694728968325593610949","6397274661015364427230613915045582313266278499204613733814533144723997400371","8289239447135302152271538605839546417853218661014808909784337448208209839379"],["0","0","0"]],"Bp":[["20018780434939681348137993935355686411827041700269658615965970389757853610060","12214991964314039865316783931020555498866124560003656342797729842023365206713","14563493435420279349650395422592820229826346263123449820617232894977970999387"],["0","0","0"],["19274528938481114377814791526884136805658142485058201128291111188915998296357","11319134201215538741944134532084533437012392966224464057344192877082320972891","1593572666518915656000637407242705056790260319730981223924868331168260242449"],["0","0","0"],["0","0","0"],["0","0","0"],["0","0","0"],["0","0","0"]],"Cp":[["0","0","0"],["14987227002519402401359841510768304665057543070376416931019432865238411881373","4707895417838638711612830595553391676214246525936871977687639690199976052742","17404086172672623228193483870496542757414022042455907126449959180813980194773"],["0","0","0"],["16014836084107670530502498025633394447105169997401771603866344164565660540973","20235483341184415292875962913426672632727141159620557462454344181386411192357","19333921793661249086188773173741885819349336071811123445234475710091821184997"],["12490952236165464028751046327529873153947842808903658123722900467139035958314","847512381539492768958412219292953032928469010943979052909089966885101136845","4184102947332631027232961712919297966146030658948066145861361929711365988039"],["5123818148326232257245867142221882926648873724312852831604116546492362380508","19044410175328600074008795135278295722267991800599159011122500985820973438460","5015595052313212324194813708153870196673017569081232632586001237044929654040"],["15978580101259669822312864668490348182406207205048917713158641372796675169523","8364084821959862858099098975080346721532738543672583975603478487742174982833","2319477857884936519784662361436527615659625357181614654126959744602265664688"],["20682997069429442890771013480814916377706173671426676880788124657265474725432","18660989240828625870452952266849945193634768111915852064783696435779861308955","3517407932972985341499660388830421377171132598336429919477261029159940762388"]],"Z":["720","21888242871839275222246405745257275088548364400416034343698204186575808493853","1624","21888242871839275222246405745257275088548364400416034343698204186575808494882","175","21888242871839275222246405745257275088548364400416034343698204186575808495596","1"]},"Vk":{"Vka":[["20214571844042784668277636692905197466177419439964686731196189932981920590822","15276326414920997693778417011131896891285513750682271416430716961378882594519"],["16498035158192775354342900050792858826389458032456459122216986217940526372057","20991711584316395543077614973508465836613050901314901591480745784166147200174"],["6554187966347558329138786326314231043574337655348545603106486528529616191262","3329049453466022164817299141240290667596535381768743742083160916011303392614"]],"Vkb":["18601699720276287321203962347637511035834839448990340830509726610548371325938","1404033020547542514452780713672814114407357194997099157699901438205943518993","9878628437561206917036168906193330943231851856412294605073956359601611464573"],"Vkc":[["11201726330257670413254165918954792292808047052763030911614100485460506324887","934969546379598639340650175600025064266557353863820319935819231249163270767"],["13304404400663675184865999338606690656572060605272848711326915297751075541966","11378789116609243263745403165917762883252438608536455003337239566234909822227"],["17466827643606195162625697931726983774172034013958787179396969407079370356584","15000536982475601439524169813356540143374565850393853241584230104237035092676"]],"IC":[["7174206590592787125297180086710023841226950848202094190665117479806387137883","17652025361381698291522443621361023414364698651922621167014090353827449887602","14028631817708334859212193494275677331425051891495047854336610288692893108523"],["9496211367937653129316339857607539932181489693017062849205858418506655217336","20715527976204177150125765369524021558336699683501368910122162008825354750707","18144702909222194940950017253098692203736826433930172591650227400416842046007"]],"G1Kbg":["19565810405534790741082831936064612684475555528159464341421930532575157635016","9799284072503001264378302942679352604989683608693688725866622459096256374574","5439756270363982397635037014986730980256257574257202393692990560225837703460"],"G2Kbg":[["7203663164634332596159832593371068902137670685197048804721245666572399446641","9647927520523281739632004193430205551282338357864496740791607437771659434446"],["12635628955805234822373808404031007162830931332162422406930356235594909536097","4525590619102035023419475118621776377495537374130624082096973427302753356672"],["10340977129747011226703015997599340344360948786234691736499821757268703108360","10313061803116028699328887269171348446722130367355951387162443297447631257052"]],"G2Kg":[["3530878578326465145608159294456745500351881239330516635657099408154033928513","12828533343030757742027018294000229952634862390599660668826878515412669227723"],["1555565908497920970072864259284092943250038177120380161621820719610403685807","3695200516686918833737615149262571835341469128876911982248847228856612041601"],["21796564584401779739204868190265096884129092077989267871136514246491447614488","9849506192886271133535915496779663766139277044154034600311452060203107849389"]],"Vkz":[["11513088702254679699323010943896789023715231470824941455892216464429039145652","1625429026784522879605778124473104553417494250251020384149638852566558637730"],["21618500115441299970426725684976255792080430977789008509842208339530512020429","18998629536272373495983374392593854393457027995029334544640573238830053525634"],["4353032488604798586028070468593404321831373691185739435853683684699874655988","20116220156107780813383974456858322113922541314847440497024320298172369098679"]]}}; const px = ["21888242871839275222246405745257275088548364400416034343698204186575808491809","10214513340191661770381656014453395041322570053527482693725828620402043982207","6250309353402993035685918085034577441952144056563245362589376084388869725846","8684363028317712437715356353558094792076827912572472885439518975877531461332","4676585224700845145864220486776033543224569523514814745192926496344784986728","15086167396042000456999692848727670503739063657925634782028102538317006907054","21632626702190133686375495752236851586646219728193583201883487889998783136513","12304536531079092564172545451934558461236042348706097084183122422939664568112","5627862446735063646553285921653823681621549943926414385940458402833120205122","19793152958064844596228144454594339151253283687552138463809498762698702751890","12878849570320523547145145010088473306441356493332753911233629701770305283468","21470238233661789063488227857761042404565669941380311465606745426068284375041","14598495318168266605115151979982065705759253455717291424254733984391562089814"]; function callGenerateProof() { console.log("s", JSON.stringify(setup)) @@ -17,3 +17,15 @@ function callGenerateProof() { console.log("r", r); document.getElementById("proofResult").value = r; } + +function callVerifyProof() { + const proof = document.getElementById("proofResult").value; + let r = verifyProofs( + JSON.stringify(circuit), + JSON.stringify(setup), + proof, + JSON.stringify([35]) + ); + console.log("r", r); + alert("verified: " + r); +} diff --git a/wasm/utils/utils.go b/wasm/utils/utils.go index 91e8baf..afe36fb 100644 --- a/wasm/utils/utils.go +++ b/wasm/utils/utils.go @@ -169,6 +169,14 @@ func SetupToString(setup snark.Setup) SetupString { s.Pk.Bp = Array3BigIntToString(setup.Pk.Bp) s.Pk.Cp = Array3BigIntToString(setup.Pk.Cp) s.Pk.Z = ArrayBigIntToString(setup.Pk.Z) + s.Vk.Vka = BigInt32ToString(setup.Vk.Vka) + s.Vk.Vkb = BigInt3ToString(setup.Vk.Vkb) + s.Vk.Vkc = BigInt32ToString(setup.Vk.Vkc) + s.Vk.IC = Array3BigIntToString(setup.Vk.IC) + s.Vk.G1Kbg = BigInt3ToString(setup.Vk.G1Kbg) + s.Vk.G2Kbg = BigInt32ToString(setup.Vk.G2Kbg) + s.Vk.G2Kg = BigInt32ToString(setup.Vk.G2Kg) + s.Vk.Vkz = BigInt32ToString(setup.Vk.Vkz) return s } func SetupFromString(s SetupString) (snark.Setup, error) { @@ -214,6 +222,40 @@ func SetupFromString(s SetupString) (snark.Setup, error) { if err != nil { return o, err } + + o.Vk.Vka, err = String32ToBigInt(s.Vk.Vka) + if err != nil { + return o, err + } + o.Vk.Vkb, err = String3ToBigInt(s.Vk.Vkb) + if err != nil { + return o, err + } + o.Vk.Vkc, err = String32ToBigInt(s.Vk.Vkc) + if err != nil { + return o, err + } + o.Vk.IC, err = Array3StringToBigInt(s.Vk.IC) + if err != nil { + return o, err + } + o.Vk.G1Kbg, err = String3ToBigInt(s.Vk.G1Kbg) + if err != nil { + return o, err + } + o.Vk.G2Kbg, err = String32ToBigInt(s.Vk.G2Kbg) + if err != nil { + return o, err + } + o.Vk.G2Kg, err = String32ToBigInt(s.Vk.G2Kg) + if err != nil { + return o, err + } + o.Vk.Vkz, err = String32ToBigInt(s.Vk.Vkz) + if err != nil { + return o, err + } + return o, nil }