From ca80924e38ee583c6e36df7fcf34face3192884b Mon Sep 17 00:00:00 2001 From: agessaman Date: Sat, 10 Jan 2026 16:39:07 -0800 Subject: [PATCH] feat: Enhance web viewer functionality and configuration options - Updated `config.ini.example` to include a new option for additional hashtag channels to decode in the packet stream. - Modified `BotDataViewer` to retrieve and display additional decode-only channels from the configuration. - Improved packet handling in `message_handler.py` to capture full packet data for web viewer integration. - Enhanced the web viewer's JavaScript to support detailed packet analysis and display, including color-coded hex breakdowns and improved user interface elements. - Added new styles and scripts to the web viewer templates for better visual representation of packet data and improved user experience. --- README.md | 1 + config.ini.example | 15 +- modules/message_handler.py | 4 + modules/web_viewer/app.py | 77 +- modules/web_viewer/integration.py | 5 + .../static/js/meshcore-browser.min.mjs | 31 + .../web_viewer/static/js/meshcore-browser.mjs | 9968 +++++++++++++++++ modules/web_viewer/templates/base.html | 5 +- modules/web_viewer/templates/radio.html | 3 +- modules/web_viewer/templates/realtime.html | 1497 ++- 10 files changed, 11481 insertions(+), 125 deletions(-) create mode 100644 modules/web_viewer/static/js/meshcore-browser.min.mjs create mode 100644 modules/web_viewer/static/js/meshcore-browser.mjs diff --git a/README.md b/README.md index 622cc1d..b3b960b 100644 --- a/README.md +++ b/README.md @@ -332,3 +332,4 @@ This project is licensed under the MIT License. - [MeshCore Project](https://github.com/meshcore-dev/MeshCore) for the mesh networking protocol - Some commands adapted from MeshingAround bot by K7MHI Kelly Keeton 2024 - Packet capture service based on [meshcore-packet-capture](https://github.com/agessaman/meshcore-packet-capture) by agessaman +- [meshcore-decoder](https://github.com/michaelhart/meshcore-decoder) by Michael Hart for client-side packet decoding and decryption in the web viewer diff --git a/config.ini.example b/config.ini.example index b4a2a76..f5f5f1d 100644 --- a/config.ini.example +++ b/config.ini.example @@ -262,7 +262,7 @@ ping = "Pong!" pong = "Ping!" help = "Bot Help: test (or t), ping, help, hello, cmd, advert, @string, wx, aqi, sun, moon, solar, hfcond, satpass, prefix, path, sports, dice, roll, stats | More: 'help '" -Override 'cmd' command output +# Override 'cmd' command output # cmd = "Available commands: test (or t), ping, help, hello, cmd, advert, @string, wx, aqi, sun, moon, solar, hfcond, satpass, prefix, path, sports, dice, roll, stats" [Channels] @@ -806,6 +806,19 @@ auto_start = false # Default: bot_data.db db_path = bot_data.db +# Additional hashtag channels to decode in the packet stream +# The web viewer can decrypt GroupText messages from hashtag channels +# without adding them to the radio. Enter channel names (with or without #) +# as a comma-separated list. The Public channel is always included. +# +# Example: #CQ,#ARES,#EmComm +# This will allow decryption of messages on #CQ, #ARES, and #EmComm channels +# in addition to any channels configured on your radio. +# +# Note: Only hashtag channels work here - custom channels with private keys +# must be added to the radio itself. +decode_hashtag_channels = + #################################################################################################### # # # Service Plugins Config # diff --git a/modules/message_handler.py b/modules/message_handler.py index 0682aa6..979fb4d 100644 --- a/modules/message_handler.py +++ b/modules/message_handler.py @@ -668,6 +668,10 @@ class MessageHandler: if (hasattr(self.bot, 'web_viewer_integration') and self.bot.web_viewer_integration and self.bot.web_viewer_integration.bot_integration): + # Use extracted_payload which is the full MeshCore packet + # (header + path_len + path + payload, without RF wrapper) + decoded_packet['raw_packet_hex'] = extracted_payload if extracted_payload else raw_hex + decoded_packet['packet_hash'] = packet_hash self.bot.web_viewer_integration.bot_integration.capture_full_packet_data(decoded_packet) # Process ADVERT packets for contact tracking (regardless of path length) diff --git a/modules/web_viewer/app.py b/modules/web_viewer/app.py index 893c55e..41e98ba 100644 --- a/modules/web_viewer/app.py +++ b/modules/web_viewer/app.py @@ -37,7 +37,12 @@ class BotDataViewer: # This is the directory containing the modules folder self.bot_root = Path(os.path.join(os.path.dirname(__file__), '..', '..')).resolve() - self.app = Flask(__name__, template_folder=os.path.join(os.path.dirname(__file__), 'templates')) + self.app = Flask( + __name__, + template_folder=os.path.join(os.path.dirname(__file__), 'templates'), + static_folder=os.path.join(os.path.dirname(__file__), 'static'), + static_url_path='/static' + ) self.app.config['SECRET_KEY'] = 'meshcore_bot_viewer_secret' # Flask-SocketIO configuration following 5.x best practices @@ -2933,33 +2938,57 @@ class BotDataViewer: return [] def _get_channels(self): - """Get all configured channels from database""" + """Get all configured channels from database plus additional decode-only channels""" import sqlite3 conn = None try: conn = self._get_db_connection() conn.row_factory = sqlite3.Row cursor = conn.cursor() - + cursor.execute(''' SELECT channel_idx, channel_name, channel_type, channel_key_hex, last_updated FROM channels ORDER BY channel_idx ''') - + rows = cursor.fetchall() channels = [] + existing_names = set() + for row in rows: + name = row['channel_name'] channels.append({ 'channel_idx': row['channel_idx'], 'index': row['channel_idx'], # Alias for compatibility - 'name': row['channel_name'], - 'channel_name': row['channel_name'], # Alias for compatibility + 'name': name, + 'channel_name': name, # Alias for compatibility 'type': row['channel_type'] or 'hashtag', 'key_hex': row['channel_key_hex'], 'last_updated': row['last_updated'] }) - + # Track names for deduplication (normalize to lowercase with #) + normalized = name.lower() if name.startswith('#') else f'#{name.lower()}' + existing_names.add(normalized) + + # Add additional decode-only hashtag channels from config + additional_channels = self._get_additional_decode_channels() + for channel_name in additional_channels: + # Normalize name + normalized = channel_name.lower() if channel_name.startswith('#') else f'#{channel_name.lower()}' + if normalized not in existing_names: + channels.append({ + 'channel_idx': None, # Not a real radio channel + 'index': None, + 'name': normalized, + 'channel_name': normalized, + 'type': 'hashtag', + 'key_hex': None, # Key will be derived client-side + 'last_updated': None, + 'decode_only': True # Flag to indicate this is decode-only + }) + existing_names.add(normalized) + return channels except Exception as e: self.logger.error(f"Error getting channels: {e}") @@ -2968,6 +2997,40 @@ class BotDataViewer: if conn: conn.close() + def _get_additional_decode_channels(self): + """Get additional hashtag channels to decode from config""" + channels = set() # Use set for automatic deduplication + + try: + # 1. Get channels from decode_hashtag_channels in [Web_Viewer] + if self.config and self.config.has_option('Web_Viewer', 'decode_hashtag_channels'): + channels_str = self.config.get('Web_Viewer', 'decode_hashtag_channels', fallback='') + if channels_str: + for c in channels_str.split(','): + c = c.strip().lower() + if c: + # Remove # prefix if present for normalization + if c.startswith('#'): + c = c[1:] + channels.add(c) + + # 2. Import channels from [Channels_List] section + if self.config and self.config.has_section('Channels_List'): + for key in self.config.options('Channels_List'): + # Handle categorized channels like "sports.sounders" -> "sounders" + if '.' in key: + channel_name = key.split('.')[-1] # Get part after last dot + else: + channel_name = key + + channel_name = channel_name.strip().lower() + if channel_name: + channels.add(channel_name) + except Exception as e: + self.logger.error(f"Error reading decode channels config: {e}") + + return list(channels) + def _get_channel_number(self, channel_name): """Get channel number from channel name""" # This would use channel_manager diff --git a/modules/web_viewer/integration.py b/modules/web_viewer/integration.py index 5d155dd..9e0198d 100644 --- a/modules/web_viewer/integration.py +++ b/modules/web_viewer/integration.py @@ -84,6 +84,7 @@ class BotIntegration: import sqlite3 import json import time + from datetime import datetime # Ensure packet_data is a dict (might be passed as dict already) if not isinstance(packet_data, dict): @@ -100,6 +101,10 @@ class BotIntegration: # If no path_len either, default to 0 hops packet_data['hops'] = 0 + # Add datetime for frontend display + if 'datetime' not in packet_data: + packet_data['datetime'] = datetime.now().isoformat() + # Convert non-serializable objects to strings serializable_data = self._make_json_serializable(packet_data) diff --git a/modules/web_viewer/static/js/meshcore-browser.min.mjs b/modules/web_viewer/static/js/meshcore-browser.min.mjs new file mode 100644 index 0000000..79f561b --- /dev/null +++ b/modules/web_viewer/static/js/meshcore-browser.min.mjs @@ -0,0 +1,31 @@ +var Nn=Object.create;var Rt=Object.defineProperty;var Kn=Object.getOwnPropertyDescriptor;var Ln=Object.getOwnPropertyNames;var Wn=Object.getPrototypeOf,Mn=Object.prototype.hasOwnProperty;var ee=(s=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(s,{get:(e,t)=>(typeof require<"u"?require:e)[t]}):s)(function(s){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+s+'" is not supported')});var M=(s,e)=>()=>(e||s((e={exports:{}}).exports,e),e.exports),In=(s,e)=>{for(var t in e)Rt(s,t,{get:e[t],enumerable:!0})},$n=(s,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let a of Ln(e))!Mn.call(s,a)&&a!==t&&Rt(s,a,{get:()=>e[a],enumerable:!(n=Kn(e,a))||n.enumerable});return s};var tr=(s,e,t)=>(t=s!=null?Nn(Wn(s)):{},$n(e||!s||!s.__esModule?Rt(t,"default",{value:s,enumerable:!0}):t,s));var Se=M(()=>{});var $=M((_e,Er)=>{(function(s,e){typeof _e=="object"?Er.exports=_e=e():typeof define=="function"&&define.amd?define([],e):s.CryptoJS=e()})(_e,function(){var s=s||(function(e,t){var n;if(typeof window<"u"&&window.crypto&&(n=window.crypto),typeof self<"u"&&self.crypto&&(n=self.crypto),typeof globalThis<"u"&&globalThis.crypto&&(n=globalThis.crypto),!n&&typeof window<"u"&&window.msCrypto&&(n=window.msCrypto),!n&&typeof global<"u"&&global.crypto&&(n=global.crypto),!n&&typeof ee=="function")try{n=Se()}catch{}var a=function(){if(n){if(typeof n.getRandomValues=="function")try{return n.getRandomValues(new Uint32Array(1))[0]}catch{}if(typeof n.randomBytes=="function")try{return n.randomBytes(4).readInt32LE()}catch{}}throw new Error("Native crypto module could not be used to get secure random number.")},r=Object.create||(function(){function l(){}return function(v){var C;return l.prototype=v,C=new l,l.prototype=null,C}})(),c={},i=c.lib={},f=i.Base=(function(){return{extend:function(l){var v=r(this);return l&&v.mixIn(l),(!v.hasOwnProperty("init")||this.init===v.init)&&(v.init=function(){v.$super.init.apply(this,arguments)}),v.init.prototype=v,v.$super=this,v},create:function(){var l=this.extend();return l.init.apply(l,arguments),l},init:function(){},mixIn:function(l){for(var v in l)l.hasOwnProperty(v)&&(this[v]=l[v]);l.hasOwnProperty("toString")&&(this.toString=l.toString)},clone:function(){return this.init.prototype.extend(this)}}})(),h=i.WordArray=f.extend({init:function(l,v){l=this.words=l||[],v!=t?this.sigBytes=v:this.sigBytes=l.length*4},toString:function(l){return(l||d).stringify(this)},concat:function(l){var v=this.words,C=l.words,B=this.sigBytes,A=l.sigBytes;if(this.clamp(),B%4)for(var y=0;y>>2]>>>24-y%4*8&255;v[B+y>>>2]|=w<<24-(B+y)%4*8}else for(var S=0;S>>2]=C[S>>>2];return this.sigBytes+=A,this},clamp:function(){var l=this.words,v=this.sigBytes;l[v>>>2]&=4294967295<<32-v%4*8,l.length=e.ceil(v/4)},clone:function(){var l=f.clone.call(this);return l.words=this.words.slice(0),l},random:function(l){for(var v=[],C=0;C>>2]>>>24-A%4*8&255;B.push((y>>>4).toString(16)),B.push((y&15).toString(16))}return B.join("")},parse:function(l){for(var v=l.length,C=[],B=0;B>>3]|=parseInt(l.substr(B,2),16)<<24-B%8*4;return new h.init(C,v/2)}},x=o.Latin1={stringify:function(l){for(var v=l.words,C=l.sigBytes,B=[],A=0;A>>2]>>>24-A%4*8&255;B.push(String.fromCharCode(y))}return B.join("")},parse:function(l){for(var v=l.length,C=[],B=0;B>>2]|=(l.charCodeAt(B)&255)<<24-B%4*8;return new h.init(C,v)}},u=o.Utf8={stringify:function(l){try{return decodeURIComponent(escape(x.stringify(l)))}catch{throw new Error("Malformed UTF-8 data")}},parse:function(l){return x.parse(unescape(encodeURIComponent(l)))}},p=i.BufferedBlockAlgorithm=f.extend({reset:function(){this._data=new h.init,this._nDataBytes=0},_append:function(l){typeof l=="string"&&(l=u.parse(l)),this._data.concat(l),this._nDataBytes+=l.sigBytes},_process:function(l){var v,C=this._data,B=C.words,A=C.sigBytes,y=this.blockSize,w=y*4,S=A/w;l?S=e.ceil(S):S=e.max((S|0)-this._minBufferSize,0);var T=S*y,q=e.min(T*4,A);if(T){for(var E=0;E{(function(s,e){typeof we=="object"?Dr.exports=we=e($()):typeof define=="function"&&define.amd?define(["./core"],e):e(s.CryptoJS)})(we,function(s){return(function(e){var t=s,n=t.lib,a=n.Base,r=n.WordArray,c=t.x64={},i=c.Word=a.extend({init:function(h,o){this.high=h,this.low=o}}),f=c.WordArray=a.extend({init:function(h,o){h=this.words=h||[],o!=e?this.sigBytes=o:this.sigBytes=h.length*8},toX32:function(){for(var h=this.words,o=h.length,d=[],x=0;x{(function(s,e){typeof ke=="object"?br.exports=ke=e($()):typeof define=="function"&&define.amd?define(["./core"],e):e(s.CryptoJS)})(ke,function(s){return(function(){if(typeof ArrayBuffer=="function"){var e=s,t=e.lib,n=t.WordArray,a=n.init,r=n.init=function(c){if(c instanceof ArrayBuffer&&(c=new Uint8Array(c)),(c instanceof Int8Array||typeof Uint8ClampedArray<"u"&&c instanceof Uint8ClampedArray||c instanceof Int16Array||c instanceof Uint16Array||c instanceof Int32Array||c instanceof Uint32Array||c instanceof Float32Array||c instanceof Float64Array)&&(c=new Uint8Array(c.buffer,c.byteOffset,c.byteLength)),c instanceof Uint8Array){for(var i=c.byteLength,f=[],h=0;h>>2]|=c[h]<<24-h%4*8;a.call(this,f,i)}else a.apply(this,arguments)};r.prototype=n}})(),s.lib.WordArray})});var _r=M((Pe,Sr)=>{(function(s,e){typeof Pe=="object"?Sr.exports=Pe=e($()):typeof define=="function"&&define.amd?define(["./core"],e):e(s.CryptoJS)})(Pe,function(s){return(function(){var e=s,t=e.lib,n=t.WordArray,a=e.enc,r=a.Utf16=a.Utf16BE={stringify:function(i){for(var f=i.words,h=i.sigBytes,o=[],d=0;d>>2]>>>16-d%4*8&65535;o.push(String.fromCharCode(x))}return o.join("")},parse:function(i){for(var f=i.length,h=[],o=0;o>>1]|=i.charCodeAt(o)<<16-o%2*16;return n.create(h,f*2)}};a.Utf16LE={stringify:function(i){for(var f=i.words,h=i.sigBytes,o=[],d=0;d>>2]>>>16-d%4*8&65535);o.push(String.fromCharCode(x))}return o.join("")},parse:function(i){for(var f=i.length,h=[],o=0;o>>1]|=c(i.charCodeAt(o)<<16-o%2*16);return n.create(h,f*2)}};function c(i){return i<<8&4278255360|i>>>8&16711935}})(),s.enc.Utf16})});var w0=M((He,wr)=>{(function(s,e){typeof He=="object"?wr.exports=He=e($()):typeof define=="function"&&define.amd?define(["./core"],e):e(s.CryptoJS)})(He,function(s){return(function(){var e=s,t=e.lib,n=t.WordArray,a=e.enc,r=a.Base64={stringify:function(i){var f=i.words,h=i.sigBytes,o=this._map;i.clamp();for(var d=[],x=0;x>>2]>>>24-x%4*8&255,p=f[x+1>>>2]>>>24-(x+1)%4*8&255,g=f[x+2>>>2]>>>24-(x+2)%4*8&255,m=u<<16|p<<8|g,l=0;l<4&&x+l*.75>>6*(3-l)&63));var v=o.charAt(64);if(v)for(;d.length%4;)d.push(v);return d.join("")},parse:function(i){var f=i.length,h=this._map,o=this._reverseMap;if(!o){o=this._reverseMap=[];for(var d=0;d>>6-x%4*2,g=u|p;o[d>>>2]|=g<<24-d%4*8,d++}return n.create(o,d)}})(),s.enc.Base64})});var Pr=M((Re,kr)=>{(function(s,e){typeof Re=="object"?kr.exports=Re=e($()):typeof define=="function"&&define.amd?define(["./core"],e):e(s.CryptoJS)})(Re,function(s){return(function(){var e=s,t=e.lib,n=t.WordArray,a=e.enc,r=a.Base64url={stringify:function(i,f){f===void 0&&(f=!0);var h=i.words,o=i.sigBytes,d=f?this._safe_map:this._map;i.clamp();for(var x=[],u=0;u>>2]>>>24-u%4*8&255,g=h[u+1>>>2]>>>24-(u+1)%4*8&255,m=h[u+2>>>2]>>>24-(u+2)%4*8&255,l=p<<16|g<<8|m,v=0;v<4&&u+v*.75>>6*(3-v)&63));var C=d.charAt(64);if(C)for(;x.length%4;)x.push(C);return x.join("")},parse:function(i,f){f===void 0&&(f=!0);var h=i.length,o=f?this._safe_map:this._map,d=this._reverseMap;if(!d){d=this._reverseMap=[];for(var x=0;x>>6-x%4*2,g=u|p;o[d>>>2]|=g<<24-d%4*8,d++}return n.create(o,d)}})(),s.enc.Base64url})});var k0=M((Te,Hr)=>{(function(s,e){typeof Te=="object"?Hr.exports=Te=e($()):typeof define=="function"&&define.amd?define(["./core"],e):e(s.CryptoJS)})(Te,function(s){return(function(e){var t=s,n=t.lib,a=n.WordArray,r=n.Hasher,c=t.algo,i=[];(function(){for(var u=0;u<64;u++)i[u]=e.abs(e.sin(u+1))*4294967296|0})();var f=c.MD5=r.extend({_doReset:function(){this._hash=new a.init([1732584193,4023233417,2562383102,271733878])},_doProcessBlock:function(u,p){for(var g=0;g<16;g++){var m=p+g,l=u[m];u[m]=(l<<8|l>>>24)&16711935|(l<<24|l>>>8)&4278255360}var v=this._hash.words,C=u[p+0],B=u[p+1],A=u[p+2],y=u[p+3],w=u[p+4],S=u[p+5],T=u[p+6],q=u[p+7],E=u[p+8],H=u[p+9],U=u[p+10],k=u[p+11],K=u[p+12],N=u[p+13],L=u[p+14],I=u[p+15],b=v[0],_=v[1],P=v[2],F=v[3];b=h(b,_,P,F,C,7,i[0]),F=h(F,b,_,P,B,12,i[1]),P=h(P,F,b,_,A,17,i[2]),_=h(_,P,F,b,y,22,i[3]),b=h(b,_,P,F,w,7,i[4]),F=h(F,b,_,P,S,12,i[5]),P=h(P,F,b,_,T,17,i[6]),_=h(_,P,F,b,q,22,i[7]),b=h(b,_,P,F,E,7,i[8]),F=h(F,b,_,P,H,12,i[9]),P=h(P,F,b,_,U,17,i[10]),_=h(_,P,F,b,k,22,i[11]),b=h(b,_,P,F,K,7,i[12]),F=h(F,b,_,P,N,12,i[13]),P=h(P,F,b,_,L,17,i[14]),_=h(_,P,F,b,I,22,i[15]),b=o(b,_,P,F,B,5,i[16]),F=o(F,b,_,P,T,9,i[17]),P=o(P,F,b,_,k,14,i[18]),_=o(_,P,F,b,C,20,i[19]),b=o(b,_,P,F,S,5,i[20]),F=o(F,b,_,P,U,9,i[21]),P=o(P,F,b,_,I,14,i[22]),_=o(_,P,F,b,w,20,i[23]),b=o(b,_,P,F,H,5,i[24]),F=o(F,b,_,P,L,9,i[25]),P=o(P,F,b,_,y,14,i[26]),_=o(_,P,F,b,E,20,i[27]),b=o(b,_,P,F,N,5,i[28]),F=o(F,b,_,P,A,9,i[29]),P=o(P,F,b,_,q,14,i[30]),_=o(_,P,F,b,K,20,i[31]),b=d(b,_,P,F,S,4,i[32]),F=d(F,b,_,P,E,11,i[33]),P=d(P,F,b,_,k,16,i[34]),_=d(_,P,F,b,L,23,i[35]),b=d(b,_,P,F,B,4,i[36]),F=d(F,b,_,P,w,11,i[37]),P=d(P,F,b,_,q,16,i[38]),_=d(_,P,F,b,U,23,i[39]),b=d(b,_,P,F,N,4,i[40]),F=d(F,b,_,P,C,11,i[41]),P=d(P,F,b,_,y,16,i[42]),_=d(_,P,F,b,T,23,i[43]),b=d(b,_,P,F,H,4,i[44]),F=d(F,b,_,P,K,11,i[45]),P=d(P,F,b,_,I,16,i[46]),_=d(_,P,F,b,A,23,i[47]),b=x(b,_,P,F,C,6,i[48]),F=x(F,b,_,P,q,10,i[49]),P=x(P,F,b,_,L,15,i[50]),_=x(_,P,F,b,S,21,i[51]),b=x(b,_,P,F,K,6,i[52]),F=x(F,b,_,P,y,10,i[53]),P=x(P,F,b,_,U,15,i[54]),_=x(_,P,F,b,B,21,i[55]),b=x(b,_,P,F,E,6,i[56]),F=x(F,b,_,P,I,10,i[57]),P=x(P,F,b,_,T,15,i[58]),_=x(_,P,F,b,N,21,i[59]),b=x(b,_,P,F,w,6,i[60]),F=x(F,b,_,P,k,10,i[61]),P=x(P,F,b,_,A,15,i[62]),_=x(_,P,F,b,H,21,i[63]),v[0]=v[0]+b|0,v[1]=v[1]+_|0,v[2]=v[2]+P|0,v[3]=v[3]+F|0},_doFinalize:function(){var u=this._data,p=u.words,g=this._nDataBytes*8,m=u.sigBytes*8;p[m>>>5]|=128<<24-m%32;var l=e.floor(g/4294967296),v=g;p[(m+64>>>9<<4)+15]=(l<<8|l>>>24)&16711935|(l<<24|l>>>8)&4278255360,p[(m+64>>>9<<4)+14]=(v<<8|v>>>24)&16711935|(v<<24|v>>>8)&4278255360,u.sigBytes=(p.length+1)*4,this._process();for(var C=this._hash,B=C.words,A=0;A<4;A++){var y=B[A];B[A]=(y<<8|y>>>24)&16711935|(y<<24|y>>>8)&4278255360}return C},clone:function(){var u=r.clone.call(this);return u._hash=this._hash.clone(),u}});function h(u,p,g,m,l,v,C){var B=u+(p&g|~p&m)+l+C;return(B<>>32-v)+p}function o(u,p,g,m,l,v,C){var B=u+(p&m|g&~m)+l+C;return(B<>>32-v)+p}function d(u,p,g,m,l,v,C){var B=u+(p^g^m)+l+C;return(B<>>32-v)+p}function x(u,p,g,m,l,v,C){var B=u+(g^(p|~m))+l+C;return(B<>>32-v)+p}t.MD5=r._createHelper(f),t.HmacMD5=r._createHmacHelper(f)})(Math),s.MD5})});var jt=M((qe,Rr)=>{(function(s,e){typeof qe=="object"?Rr.exports=qe=e($()):typeof define=="function"&&define.amd?define(["./core"],e):e(s.CryptoJS)})(qe,function(s){return(function(){var e=s,t=e.lib,n=t.WordArray,a=t.Hasher,r=e.algo,c=[],i=r.SHA1=a.extend({_doReset:function(){this._hash=new n.init([1732584193,4023233417,2562383102,271733878,3285377520])},_doProcessBlock:function(f,h){for(var o=this._hash.words,d=o[0],x=o[1],u=o[2],p=o[3],g=o[4],m=0;m<80;m++){if(m<16)c[m]=f[h+m]|0;else{var l=c[m-3]^c[m-8]^c[m-14]^c[m-16];c[m]=l<<1|l>>>31}var v=(d<<5|d>>>27)+g+c[m];m<20?v+=(x&u|~x&p)+1518500249:m<40?v+=(x^u^p)+1859775393:m<60?v+=(x&u|x&p|u&p)-1894007588:v+=(x^u^p)-899497514,g=p,p=u,u=x<<30|x>>>2,x=d,d=v}o[0]=o[0]+d|0,o[1]=o[1]+x|0,o[2]=o[2]+u|0,o[3]=o[3]+p|0,o[4]=o[4]+g|0},_doFinalize:function(){var f=this._data,h=f.words,o=this._nDataBytes*8,d=f.sigBytes*8;return h[d>>>5]|=128<<24-d%32,h[(d+64>>>9<<4)+14]=Math.floor(o/4294967296),h[(d+64>>>9<<4)+15]=o,f.sigBytes=h.length*4,this._process(),this._hash},clone:function(){var f=a.clone.call(this);return f._hash=this._hash.clone(),f}});e.SHA1=a._createHelper(i),e.HmacSHA1=a._createHmacHelper(i)})(),s.SHA1})});var Ve=M((Ue,Tr)=>{(function(s,e){typeof Ue=="object"?Tr.exports=Ue=e($()):typeof define=="function"&&define.amd?define(["./core"],e):e(s.CryptoJS)})(Ue,function(s){return(function(e){var t=s,n=t.lib,a=n.WordArray,r=n.Hasher,c=t.algo,i=[],f=[];(function(){function d(g){for(var m=e.sqrt(g),l=2;l<=m;l++)if(!(g%l))return!1;return!0}function x(g){return(g-(g|0))*4294967296|0}for(var u=2,p=0;p<64;)d(u)&&(p<8&&(i[p]=x(e.pow(u,1/2))),f[p]=x(e.pow(u,1/3)),p++),u++})();var h=[],o=c.SHA256=r.extend({_doReset:function(){this._hash=new a.init(i.slice(0))},_doProcessBlock:function(d,x){for(var u=this._hash.words,p=u[0],g=u[1],m=u[2],l=u[3],v=u[4],C=u[5],B=u[6],A=u[7],y=0;y<64;y++){if(y<16)h[y]=d[x+y]|0;else{var w=h[y-15],S=(w<<25|w>>>7)^(w<<14|w>>>18)^w>>>3,T=h[y-2],q=(T<<15|T>>>17)^(T<<13|T>>>19)^T>>>10;h[y]=S+h[y-7]+q+h[y-16]}var E=v&C^~v&B,H=p&g^p&m^g&m,U=(p<<30|p>>>2)^(p<<19|p>>>13)^(p<<10|p>>>22),k=(v<<26|v>>>6)^(v<<21|v>>>11)^(v<<7|v>>>25),K=A+k+E+f[y]+h[y],N=U+H;A=B,B=C,C=v,v=l+K|0,l=m,m=g,g=p,p=K+N|0}u[0]=u[0]+p|0,u[1]=u[1]+g|0,u[2]=u[2]+m|0,u[3]=u[3]+l|0,u[4]=u[4]+v|0,u[5]=u[5]+C|0,u[6]=u[6]+B|0,u[7]=u[7]+A|0},_doFinalize:function(){var d=this._data,x=d.words,u=this._nDataBytes*8,p=d.sigBytes*8;return x[p>>>5]|=128<<24-p%32,x[(p+64>>>9<<4)+14]=e.floor(u/4294967296),x[(p+64>>>9<<4)+15]=u,d.sigBytes=x.length*4,this._process(),this._hash},clone:function(){var d=r.clone.call(this);return d._hash=this._hash.clone(),d}});t.SHA256=r._createHelper(o),t.HmacSHA256=r._createHmacHelper(o)})(Math),s.SHA256})});var Ur=M((ze,qr)=>{(function(s,e,t){typeof ze=="object"?qr.exports=ze=e($(),Ve()):typeof define=="function"&&define.amd?define(["./core","./sha256"],e):e(s.CryptoJS)})(ze,function(s){return(function(){var e=s,t=e.lib,n=t.WordArray,a=e.algo,r=a.SHA256,c=a.SHA224=r.extend({_doReset:function(){this._hash=new n.init([3238371032,914150663,812702999,4144912697,4290775857,1750603025,1694076839,3204075428])},_doFinalize:function(){var i=r._doFinalize.call(this);return i.sigBytes-=4,i}});e.SHA224=r._createHelper(c),e.HmacSHA224=r._createHmacHelper(c)})(),s.SHA224})});var Xt=M((Oe,Vr)=>{(function(s,e,t){typeof Oe=="object"?Vr.exports=Oe=e($(),se()):typeof define=="function"&&define.amd?define(["./core","./x64-core"],e):e(s.CryptoJS)})(Oe,function(s){return(function(){var e=s,t=e.lib,n=t.Hasher,a=e.x64,r=a.Word,c=a.WordArray,i=e.algo;function f(){return r.create.apply(r,arguments)}var h=[f(1116352408,3609767458),f(1899447441,602891725),f(3049323471,3964484399),f(3921009573,2173295548),f(961987163,4081628472),f(1508970993,3053834265),f(2453635748,2937671579),f(2870763221,3664609560),f(3624381080,2734883394),f(310598401,1164996542),f(607225278,1323610764),f(1426881987,3590304994),f(1925078388,4068182383),f(2162078206,991336113),f(2614888103,633803317),f(3248222580,3479774868),f(3835390401,2666613458),f(4022224774,944711139),f(264347078,2341262773),f(604807628,2007800933),f(770255983,1495990901),f(1249150122,1856431235),f(1555081692,3175218132),f(1996064986,2198950837),f(2554220882,3999719339),f(2821834349,766784016),f(2952996808,2566594879),f(3210313671,3203337956),f(3336571891,1034457026),f(3584528711,2466948901),f(113926993,3758326383),f(338241895,168717936),f(666307205,1188179964),f(773529912,1546045734),f(1294757372,1522805485),f(1396182291,2643833823),f(1695183700,2343527390),f(1986661051,1014477480),f(2177026350,1206759142),f(2456956037,344077627),f(2730485921,1290863460),f(2820302411,3158454273),f(3259730800,3505952657),f(3345764771,106217008),f(3516065817,3606008344),f(3600352804,1432725776),f(4094571909,1467031594),f(275423344,851169720),f(430227734,3100823752),f(506948616,1363258195),f(659060556,3750685593),f(883997877,3785050280),f(958139571,3318307427),f(1322822218,3812723403),f(1537002063,2003034995),f(1747873779,3602036899),f(1955562222,1575990012),f(2024104815,1125592928),f(2227730452,2716904306),f(2361852424,442776044),f(2428436474,593698344),f(2756734187,3733110249),f(3204031479,2999351573),f(3329325298,3815920427),f(3391569614,3928383900),f(3515267271,566280711),f(3940187606,3454069534),f(4118630271,4000239992),f(116418474,1914138554),f(174292421,2731055270),f(289380356,3203993006),f(460393269,320620315),f(685471733,587496836),f(852142971,1086792851),f(1017036298,365543100),f(1126000580,2618297676),f(1288033470,3409855158),f(1501505948,4234509866),f(1607167915,987167468),f(1816402316,1246189591)],o=[];(function(){for(var x=0;x<80;x++)o[x]=f()})();var d=i.SHA512=n.extend({_doReset:function(){this._hash=new c.init([new r.init(1779033703,4089235720),new r.init(3144134277,2227873595),new r.init(1013904242,4271175723),new r.init(2773480762,1595750129),new r.init(1359893119,2917565137),new r.init(2600822924,725511199),new r.init(528734635,4215389547),new r.init(1541459225,327033209)])},_doProcessBlock:function(x,u){for(var p=this._hash.words,g=p[0],m=p[1],l=p[2],v=p[3],C=p[4],B=p[5],A=p[6],y=p[7],w=g.high,S=g.low,T=m.high,q=m.low,E=l.high,H=l.low,U=v.high,k=v.low,K=C.high,N=C.low,L=B.high,I=B.low,b=A.high,_=A.low,P=y.high,F=y.low,X=w,Y=S,s0=T,W=q,g0=E,b0=H,X0=U,P0=k,d0=K,i0=N,W0=L,H0=I,Z0=b,F0=_,M0=P,R0=F,o0=0;o0<80;o0++){var x0,h0,I0=o[o0];if(o0<16)h0=I0.high=x[u+o0*2]|0,x0=I0.low=x[u+o0*2+1]|0;else{var ce=o[o0-15],m0=ce.high,T0=ce.low,St=(m0>>>1|T0<<31)^(m0>>>8|T0<<24)^m0>>>7,fe=(T0>>>1|m0<<31)^(T0>>>8|m0<<24)^(T0>>>7|m0<<25),de=o[o0-2],B0=de.high,q0=de.low,le=(B0>>>19|q0<<13)^(B0<<3|q0>>>29)^B0>>>6,ue=(q0>>>19|B0<<13)^(q0<<3|B0>>>29)^(q0>>>6|B0<<26),he=o[o0-7],ve=he.high,_t=he.low,pe=o[o0-16],wt=pe.high,ye=pe.low;x0=fe+_t,h0=St+ve+(x0>>>0>>0?1:0),x0=x0+ue,h0=h0+le+(x0>>>0>>0?1:0),x0=x0+ye,h0=h0+wt+(x0>>>0>>0?1:0),I0.high=h0,I0.low=x0}var kt=d0&W0^~d0&Z0,Y0=i0&H0^~i0&F0,ge=X&s0^X&g0^s0&g0,me=Y&W^Y&b0^W&b0,Pt=(X>>>28|Y<<4)^(X<<30|Y>>>2)^(X<<25|Y>>>7),Be=(Y>>>28|X<<4)^(Y<<30|X>>>2)^(Y<<25|X>>>7),U0=(d0>>>14|i0<<18)^(d0>>>18|i0<<14)^(d0<<23|i0>>>9),Q0=(i0>>>14|d0<<18)^(i0>>>18|d0<<14)^(i0<<23|d0>>>9),Ce=h[o0],D=Ce.high,R=Ce.low,O=R0+Q0,G=M0+U0+(O>>>0>>0?1:0),O=O+Y0,G=G+kt+(O>>>0>>0?1:0),O=O+R,G=G+D+(O>>>0>>0?1:0),O=O+x0,G=G+h0+(O>>>0>>0?1:0),j=Be+me,J=Pt+ge+(j>>>0>>0?1:0);M0=Z0,R0=F0,Z0=W0,F0=H0,W0=d0,H0=i0,i0=P0+O|0,d0=X0+G+(i0>>>0>>0?1:0)|0,X0=g0,P0=b0,g0=s0,b0=W,s0=X,W=Y,Y=O+j|0,X=G+J+(Y>>>0>>0?1:0)|0}S=g.low=S+Y,g.high=w+X+(S>>>0>>0?1:0),q=m.low=q+W,m.high=T+s0+(q>>>0>>0?1:0),H=l.low=H+b0,l.high=E+g0+(H>>>0>>0?1:0),k=v.low=k+P0,v.high=U+X0+(k>>>0>>0?1:0),N=C.low=N+i0,C.high=K+d0+(N>>>0>>0?1:0),I=B.low=I+H0,B.high=L+W0+(I>>>0>>0?1:0),_=A.low=_+F0,A.high=b+Z0+(_>>>0>>0?1:0),F=y.low=F+R0,y.high=P+M0+(F>>>0>>0?1:0)},_doFinalize:function(){var x=this._data,u=x.words,p=this._nDataBytes*8,g=x.sigBytes*8;u[g>>>5]|=128<<24-g%32,u[(g+128>>>10<<5)+30]=Math.floor(p/4294967296),u[(g+128>>>10<<5)+31]=p,x.sigBytes=u.length*4,this._process();var m=this._hash.toX32();return m},clone:function(){var x=n.clone.call(this);return x._hash=this._hash.clone(),x},blockSize:1024/32});e.SHA512=n._createHelper(d),e.HmacSHA512=n._createHmacHelper(d)})(),s.SHA512})});var Or=M((Ne,zr)=>{(function(s,e,t){typeof Ne=="object"?zr.exports=Ne=e($(),se(),Xt()):typeof define=="function"&&define.amd?define(["./core","./x64-core","./sha512"],e):e(s.CryptoJS)})(Ne,function(s){return(function(){var e=s,t=e.x64,n=t.Word,a=t.WordArray,r=e.algo,c=r.SHA512,i=r.SHA384=c.extend({_doReset:function(){this._hash=new a.init([new n.init(3418070365,3238371032),new n.init(1654270250,914150663),new n.init(2438529370,812702999),new n.init(355462360,4144912697),new n.init(1731405415,4290775857),new n.init(2394180231,1750603025),new n.init(3675008525,1694076839),new n.init(1203062813,3204075428)])},_doFinalize:function(){var f=c._doFinalize.call(this);return f.sigBytes-=16,f}});e.SHA384=c._createHelper(i),e.HmacSHA384=c._createHmacHelper(i)})(),s.SHA384})});var Kr=M((Ke,Nr)=>{(function(s,e,t){typeof Ke=="object"?Nr.exports=Ke=e($(),se()):typeof define=="function"&&define.amd?define(["./core","./x64-core"],e):e(s.CryptoJS)})(Ke,function(s){return(function(e){var t=s,n=t.lib,a=n.WordArray,r=n.Hasher,c=t.x64,i=c.Word,f=t.algo,h=[],o=[],d=[];(function(){for(var p=1,g=0,m=0;m<24;m++){h[p+5*g]=(m+1)*(m+2)/2%64;var l=g%5,v=(2*p+3*g)%5;p=l,g=v}for(var p=0;p<5;p++)for(var g=0;g<5;g++)o[p+5*g]=g+(2*p+3*g)%5*5;for(var C=1,B=0;B<24;B++){for(var A=0,y=0,w=0;w<7;w++){if(C&1){var S=(1<>>24)&16711935|(C<<24|C>>>8)&4278255360,B=(B<<8|B>>>24)&16711935|(B<<24|B>>>8)&4278255360;var A=m[v];A.high^=B,A.low^=C}for(var y=0;y<24;y++){for(var w=0;w<5;w++){for(var S=0,T=0,q=0;q<5;q++){var A=m[w+5*q];S^=A.high,T^=A.low}var E=x[w];E.high=S,E.low=T}for(var w=0;w<5;w++)for(var H=x[(w+4)%5],U=x[(w+1)%5],k=U.high,K=U.low,S=H.high^(k<<1|K>>>31),T=H.low^(K<<1|k>>>31),q=0;q<5;q++){var A=m[w+5*q];A.high^=S,A.low^=T}for(var N=1;N<25;N++){var S,T,A=m[N],L=A.high,I=A.low,b=h[N];b<32?(S=L<>>32-b,T=I<>>32-b):(S=I<>>64-b,T=L<>>64-b);var _=x[o[N]];_.high=S,_.low=T}var P=x[0],F=m[0];P.high=F.high,P.low=F.low;for(var w=0;w<5;w++)for(var q=0;q<5;q++){var N=w+5*q,A=m[N],X=x[N],Y=x[(w+1)%5+5*q],s0=x[(w+2)%5+5*q];A.high=X.high^~Y.high&s0.high,A.low=X.low^~Y.low&s0.low}var A=m[0],W=d[y];A.high^=W.high,A.low^=W.low}},_doFinalize:function(){var p=this._data,g=p.words,m=this._nDataBytes*8,l=p.sigBytes*8,v=this.blockSize*32;g[l>>>5]|=1<<24-l%32,g[(e.ceil((l+1)/v)*v>>>5)-1]|=128,p.sigBytes=g.length*4,this._process();for(var C=this._state,B=this.cfg.outputLength/8,A=B/8,y=[],w=0;w>>24)&16711935|(T<<24|T>>>8)&4278255360,q=(q<<8|q>>>24)&16711935|(q<<24|q>>>8)&4278255360,y.push(q),y.push(T)}return new a.init(y,B)},clone:function(){for(var p=r.clone.call(this),g=p._state=this._state.slice(0),m=0;m<25;m++)g[m]=g[m].clone();return p}});t.SHA3=r._createHelper(u),t.HmacSHA3=r._createHmacHelper(u)})(Math),s.SHA3})});var Wr=M((Le,Lr)=>{(function(s,e){typeof Le=="object"?Lr.exports=Le=e($()):typeof define=="function"&&define.amd?define(["./core"],e):e(s.CryptoJS)})(Le,function(s){return(function(e){var t=s,n=t.lib,a=n.WordArray,r=n.Hasher,c=t.algo,i=a.create([0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,7,4,13,1,10,6,15,3,12,0,9,5,2,14,11,8,3,10,14,4,9,15,8,1,2,7,0,6,13,11,5,12,1,9,11,10,0,8,12,4,13,3,7,15,14,5,6,2,4,0,5,9,7,12,2,10,14,1,3,8,11,6,15,13]),f=a.create([5,14,7,0,9,2,11,4,13,6,15,8,1,10,3,12,6,11,3,7,0,13,5,10,14,15,8,12,4,9,1,2,15,5,1,3,7,14,6,9,11,8,12,2,10,0,4,13,8,6,4,1,3,11,15,0,5,12,2,13,9,7,10,14,12,15,10,4,1,5,8,7,6,2,13,14,0,3,9,11]),h=a.create([11,14,15,12,5,8,7,9,11,13,14,15,6,7,9,8,7,6,8,13,11,9,7,15,7,12,15,9,11,7,13,12,11,13,6,7,14,9,13,15,14,8,13,6,5,12,7,5,11,12,14,15,14,15,9,8,9,14,5,6,8,6,5,12,9,15,5,11,6,8,13,12,5,12,13,14,11,8,5,6]),o=a.create([8,9,9,11,13,15,15,5,7,7,8,11,14,14,12,6,9,13,15,7,12,8,9,11,7,7,12,7,6,15,13,11,9,7,15,11,8,6,6,14,12,13,5,14,13,13,7,5,15,5,8,11,14,14,6,14,6,9,12,9,12,5,15,8,8,5,12,9,12,5,14,6,8,13,6,5,15,13,11,11]),d=a.create([0,1518500249,1859775393,2400959708,2840853838]),x=a.create([1352829926,1548603684,1836072691,2053994217,0]),u=c.RIPEMD160=r.extend({_doReset:function(){this._hash=a.create([1732584193,4023233417,2562383102,271733878,3285377520])},_doProcessBlock:function(B,A){for(var y=0;y<16;y++){var w=A+y,S=B[w];B[w]=(S<<8|S>>>24)&16711935|(S<<24|S>>>8)&4278255360}var T=this._hash.words,q=d.words,E=x.words,H=i.words,U=f.words,k=h.words,K=o.words,N,L,I,b,_,P,F,X,Y,s0;P=N=T[0],F=L=T[1],X=I=T[2],Y=b=T[3],s0=_=T[4];for(var W,y=0;y<80;y+=1)W=N+B[A+H[y]]|0,y<16?W+=p(L,I,b)+q[0]:y<32?W+=g(L,I,b)+q[1]:y<48?W+=m(L,I,b)+q[2]:y<64?W+=l(L,I,b)+q[3]:W+=v(L,I,b)+q[4],W=W|0,W=C(W,k[y]),W=W+_|0,N=_,_=b,b=C(I,10),I=L,L=W,W=P+B[A+U[y]]|0,y<16?W+=v(F,X,Y)+E[0]:y<32?W+=l(F,X,Y)+E[1]:y<48?W+=m(F,X,Y)+E[2]:y<64?W+=g(F,X,Y)+E[3]:W+=p(F,X,Y)+E[4],W=W|0,W=C(W,K[y]),W=W+s0|0,P=s0,s0=Y,Y=C(X,10),X=F,F=W;W=T[1]+I+Y|0,T[1]=T[2]+b+s0|0,T[2]=T[3]+_+P|0,T[3]=T[4]+N+F|0,T[4]=T[0]+L+X|0,T[0]=W},_doFinalize:function(){var B=this._data,A=B.words,y=this._nDataBytes*8,w=B.sigBytes*8;A[w>>>5]|=128<<24-w%32,A[(w+64>>>9<<4)+14]=(y<<8|y>>>24)&16711935|(y<<24|y>>>8)&4278255360,B.sigBytes=(A.length+1)*4,this._process();for(var S=this._hash,T=S.words,q=0;q<5;q++){var E=T[q];T[q]=(E<<8|E>>>24)&16711935|(E<<24|E>>>8)&4278255360}return S},clone:function(){var B=r.clone.call(this);return B._hash=this._hash.clone(),B}});function p(B,A,y){return B^A^y}function g(B,A,y){return B&A|~B&y}function m(B,A,y){return(B|~A)^y}function l(B,A,y){return B&y|A&~y}function v(B,A,y){return B^(A|~y)}function C(B,A){return B<>>32-A}t.RIPEMD160=r._createHelper(u),t.HmacRIPEMD160=r._createHmacHelper(u)})(Math),s.RIPEMD160})});var Me=M((We,Mr)=>{(function(s,e){typeof We=="object"?Mr.exports=We=e($()):typeof define=="function"&&define.amd?define(["./core"],e):e(s.CryptoJS)})(We,function(s){(function(){var e=s,t=e.lib,n=t.Base,a=e.enc,r=a.Utf8,c=e.algo,i=c.HMAC=n.extend({init:function(f,h){f=this._hasher=new f.init,typeof h=="string"&&(h=r.parse(h));var o=f.blockSize,d=o*4;h.sigBytes>d&&(h=f.finalize(h)),h.clamp();for(var x=this._oKey=h.clone(),u=this._iKey=h.clone(),p=x.words,g=u.words,m=0;m{(function(s,e,t){typeof Ie=="object"?Ir.exports=Ie=e($(),Ve(),Me()):typeof define=="function"&&define.amd?define(["./core","./sha256","./hmac"],e):e(s.CryptoJS)})(Ie,function(s){return(function(){var e=s,t=e.lib,n=t.Base,a=t.WordArray,r=e.algo,c=r.SHA256,i=r.HMAC,f=r.PBKDF2=n.extend({cfg:n.extend({keySize:128/32,hasher:c,iterations:25e4}),init:function(h){this.cfg=this.cfg.extend(h)},compute:function(h,o){for(var d=this.cfg,x=i.create(d.hasher,h),u=a.create(),p=a.create([1]),g=u.words,m=p.words,l=d.keySize,v=d.iterations;g.length{(function(s,e,t){typeof $e=="object"?Gr.exports=$e=e($(),jt(),Me()):typeof define=="function"&&define.amd?define(["./core","./sha1","./hmac"],e):e(s.CryptoJS)})($e,function(s){return(function(){var e=s,t=e.lib,n=t.Base,a=t.WordArray,r=e.algo,c=r.MD5,i=r.EvpKDF=n.extend({cfg:n.extend({keySize:128/32,hasher:c,iterations:1}),init:function(f){this.cfg=this.cfg.extend(f)},compute:function(f,h){for(var o,d=this.cfg,x=d.hasher.create(),u=a.create(),p=u.words,g=d.keySize,m=d.iterations;p.length{(function(s,e,t){typeof Ge=="object"?jr.exports=Ge=e($(),D0()):typeof define=="function"&&define.amd?define(["./core","./evpkdf"],e):e(s.CryptoJS)})(Ge,function(s){s.lib.Cipher||(function(e){var t=s,n=t.lib,a=n.Base,r=n.WordArray,c=n.BufferedBlockAlgorithm,i=t.enc,f=i.Utf8,h=i.Base64,o=t.algo,d=o.EvpKDF,x=n.Cipher=c.extend({cfg:a.extend(),createEncryptor:function(E,H){return this.create(this._ENC_XFORM_MODE,E,H)},createDecryptor:function(E,H){return this.create(this._DEC_XFORM_MODE,E,H)},init:function(E,H,U){this.cfg=this.cfg.extend(U),this._xformMode=E,this._key=H,this.reset()},reset:function(){c.reset.call(this),this._doReset()},process:function(E){return this._append(E),this._process()},finalize:function(E){E&&this._append(E);var H=this._doFinalize();return H},keySize:128/32,ivSize:128/32,_ENC_XFORM_MODE:1,_DEC_XFORM_MODE:2,_createHelper:(function(){function E(H){return typeof H=="string"?q:w}return function(H){return{encrypt:function(U,k,K){return E(k).encrypt(H,U,k,K)},decrypt:function(U,k,K){return E(k).decrypt(H,U,k,K)}}}})()}),u=n.StreamCipher=x.extend({_doFinalize:function(){var E=this._process(!0);return E},blockSize:1}),p=t.mode={},g=n.BlockCipherMode=a.extend({createEncryptor:function(E,H){return this.Encryptor.create(E,H)},createDecryptor:function(E,H){return this.Decryptor.create(E,H)},init:function(E,H){this._cipher=E,this._iv=H}}),m=p.CBC=(function(){var E=g.extend();E.Encryptor=E.extend({processBlock:function(U,k){var K=this._cipher,N=K.blockSize;H.call(this,U,k,N),K.encryptBlock(U,k),this._prevBlock=U.slice(k,k+N)}}),E.Decryptor=E.extend({processBlock:function(U,k){var K=this._cipher,N=K.blockSize,L=U.slice(k,k+N);K.decryptBlock(U,k),H.call(this,U,k,N),this._prevBlock=L}});function H(U,k,K){var N,L=this._iv;L?(N=L,this._iv=e):N=this._prevBlock;for(var I=0;I>>2]&255;E.sigBytes-=H}},C=n.BlockCipher=x.extend({cfg:x.cfg.extend({mode:m,padding:v}),reset:function(){var E;x.reset.call(this);var H=this.cfg,U=H.iv,k=H.mode;this._xformMode==this._ENC_XFORM_MODE?E=k.createEncryptor:(E=k.createDecryptor,this._minBufferSize=1),this._mode&&this._mode.__creator==E?this._mode.init(this,U&&U.words):(this._mode=E.call(k,this,U&&U.words),this._mode.__creator=E)},_doProcessBlock:function(E,H){this._mode.processBlock(E,H)},_doFinalize:function(){var E,H=this.cfg.padding;return this._xformMode==this._ENC_XFORM_MODE?(H.pad(this._data,this.blockSize),E=this._process(!0)):(E=this._process(!0),H.unpad(E)),E},blockSize:128/32}),B=n.CipherParams=a.extend({init:function(E){this.mixIn(E)},toString:function(E){return(E||this.formatter).stringify(this)}}),A=t.format={},y=A.OpenSSL={stringify:function(E){var H,U=E.ciphertext,k=E.salt;return k?H=r.create([1398893684,1701076831]).concat(k).concat(U):H=U,H.toString(h)},parse:function(E){var H,U=h.parse(E),k=U.words;return k[0]==1398893684&&k[1]==1701076831&&(H=r.create(k.slice(2,4)),k.splice(0,4),U.sigBytes-=16),B.create({ciphertext:U,salt:H})}},w=n.SerializableCipher=a.extend({cfg:a.extend({format:y}),encrypt:function(E,H,U,k){k=this.cfg.extend(k);var K=E.createEncryptor(U,k),N=K.finalize(H),L=K.cfg;return B.create({ciphertext:N,key:U,iv:L.iv,algorithm:E,mode:L.mode,padding:L.padding,blockSize:E.blockSize,formatter:k.format})},decrypt:function(E,H,U,k){k=this.cfg.extend(k),H=this._parse(H,k.format);var K=E.createDecryptor(U,k).finalize(H.ciphertext);return K},_parse:function(E,H){return typeof E=="string"?H.parse(E,this):E}}),S=t.kdf={},T=S.OpenSSL={execute:function(E,H,U,k,K){if(k||(k=r.random(64/8)),K)var N=d.create({keySize:H+U,hasher:K}).compute(E,k);else var N=d.create({keySize:H+U}).compute(E,k);var L=r.create(N.words.slice(H),U*4);return N.sigBytes=H*4,B.create({key:N,iv:L,salt:k})}},q=n.PasswordBasedCipher=w.extend({cfg:w.cfg.extend({kdf:T}),encrypt:function(E,H,U,k){k=this.cfg.extend(k);var K=k.kdf.execute(U,E.keySize,E.ivSize,k.salt,k.hasher);k.iv=K.iv;var N=w.encrypt.call(this,E,H,K.key,k);return N.mixIn(K),N},decrypt:function(E,H,U,k){k=this.cfg.extend(k),H=this._parse(H,k.format);var K=k.kdf.execute(U,E.keySize,E.ivSize,H.salt,k.hasher);k.iv=K.iv;var N=w.decrypt.call(this,E,H,K.key,k);return N}})})()})});var Zr=M((je,Xr)=>{(function(s,e,t){typeof je=="object"?Xr.exports=je=e($(),r0()):typeof define=="function"&&define.amd?define(["./core","./cipher-core"],e):e(s.CryptoJS)})(je,function(s){return s.mode.CFB=(function(){var e=s.lib.BlockCipherMode.extend();e.Encryptor=e.extend({processBlock:function(n,a){var r=this._cipher,c=r.blockSize;t.call(this,n,a,c,r),this._prevBlock=n.slice(a,a+c)}}),e.Decryptor=e.extend({processBlock:function(n,a){var r=this._cipher,c=r.blockSize,i=n.slice(a,a+c);t.call(this,n,a,c,r),this._prevBlock=i}});function t(n,a,r,c){var i,f=this._iv;f?(i=f.slice(0),this._iv=void 0):i=this._prevBlock,c.encryptBlock(i,0);for(var h=0;h{(function(s,e,t){typeof Xe=="object"?Yr.exports=Xe=e($(),r0()):typeof define=="function"&&define.amd?define(["./core","./cipher-core"],e):e(s.CryptoJS)})(Xe,function(s){return s.mode.CTR=(function(){var e=s.lib.BlockCipherMode.extend(),t=e.Encryptor=e.extend({processBlock:function(n,a){var r=this._cipher,c=r.blockSize,i=this._iv,f=this._counter;i&&(f=this._counter=i.slice(0),this._iv=void 0);var h=f.slice(0);r.encryptBlock(h,0),f[c-1]=f[c-1]+1|0;for(var o=0;o{(function(s,e,t){typeof Ze=="object"?Jr.exports=Ze=e($(),r0()):typeof define=="function"&&define.amd?define(["./core","./cipher-core"],e):e(s.CryptoJS)})(Ze,function(s){return s.mode.CTRGladman=(function(){var e=s.lib.BlockCipherMode.extend();function t(r){if((r>>24&255)===255){var c=r>>16&255,i=r>>8&255,f=r&255;c===255?(c=0,i===255?(i=0,f===255?f=0:++f):++i):++c,r=0,r+=c<<16,r+=i<<8,r+=f}else r+=1<<24;return r}function n(r){return(r[0]=t(r[0]))===0&&(r[1]=t(r[1])),r}var a=e.Encryptor=e.extend({processBlock:function(r,c){var i=this._cipher,f=i.blockSize,h=this._iv,o=this._counter;h&&(o=this._counter=h.slice(0),this._iv=void 0),n(o);var d=o.slice(0);i.encryptBlock(d,0);for(var x=0;x{(function(s,e,t){typeof Ye=="object"?tn.exports=Ye=e($(),r0()):typeof define=="function"&&define.amd?define(["./core","./cipher-core"],e):e(s.CryptoJS)})(Ye,function(s){return s.mode.OFB=(function(){var e=s.lib.BlockCipherMode.extend(),t=e.Encryptor=e.extend({processBlock:function(n,a){var r=this._cipher,c=r.blockSize,i=this._iv,f=this._keystream;i&&(f=this._keystream=i.slice(0),this._iv=void 0),r.encryptBlock(f,0);for(var h=0;h{(function(s,e,t){typeof Qe=="object"?nn.exports=Qe=e($(),r0()):typeof define=="function"&&define.amd?define(["./core","./cipher-core"],e):e(s.CryptoJS)})(Qe,function(s){return s.mode.ECB=(function(){var e=s.lib.BlockCipherMode.extend();return e.Encryptor=e.extend({processBlock:function(t,n){this._cipher.encryptBlock(t,n)}}),e.Decryptor=e.extend({processBlock:function(t,n){this._cipher.decryptBlock(t,n)}}),e})(),s.mode.ECB})});var on=M((Je,an)=>{(function(s,e,t){typeof Je=="object"?an.exports=Je=e($(),r0()):typeof define=="function"&&define.amd?define(["./core","./cipher-core"],e):e(s.CryptoJS)})(Je,function(s){return s.pad.AnsiX923={pad:function(e,t){var n=e.sigBytes,a=t*4,r=a-n%a,c=n+r-1;e.clamp(),e.words[c>>>2]|=r<<24-c%4*8,e.sigBytes+=r},unpad:function(e){var t=e.words[e.sigBytes-1>>>2]&255;e.sigBytes-=t}},s.pad.Ansix923})});var cn=M((et,xn)=>{(function(s,e,t){typeof et=="object"?xn.exports=et=e($(),r0()):typeof define=="function"&&define.amd?define(["./core","./cipher-core"],e):e(s.CryptoJS)})(et,function(s){return s.pad.Iso10126={pad:function(e,t){var n=t*4,a=n-e.sigBytes%n;e.concat(s.lib.WordArray.random(a-1)).concat(s.lib.WordArray.create([a<<24],1))},unpad:function(e){var t=e.words[e.sigBytes-1>>>2]&255;e.sigBytes-=t}},s.pad.Iso10126})});var dn=M((tt,fn)=>{(function(s,e,t){typeof tt=="object"?fn.exports=tt=e($(),r0()):typeof define=="function"&&define.amd?define(["./core","./cipher-core"],e):e(s.CryptoJS)})(tt,function(s){return s.pad.Iso97971={pad:function(e,t){e.concat(s.lib.WordArray.create([2147483648],1)),s.pad.ZeroPadding.pad(e,t)},unpad:function(e){s.pad.ZeroPadding.unpad(e),e.sigBytes--}},s.pad.Iso97971})});var un=M((rt,ln)=>{(function(s,e,t){typeof rt=="object"?ln.exports=rt=e($(),r0()):typeof define=="function"&&define.amd?define(["./core","./cipher-core"],e):e(s.CryptoJS)})(rt,function(s){return s.pad.ZeroPadding={pad:function(e,t){var n=t*4;e.clamp(),e.sigBytes+=n-(e.sigBytes%n||n)},unpad:function(e){for(var t=e.words,n=e.sigBytes-1,n=e.sigBytes-1;n>=0;n--)if(t[n>>>2]>>>24-n%4*8&255){e.sigBytes=n+1;break}}},s.pad.ZeroPadding})});var vn=M((nt,hn)=>{(function(s,e,t){typeof nt=="object"?hn.exports=nt=e($(),r0()):typeof define=="function"&&define.amd?define(["./core","./cipher-core"],e):e(s.CryptoJS)})(nt,function(s){return s.pad.NoPadding={pad:function(){},unpad:function(){}},s.pad.NoPadding})});var yn=M((st,pn)=>{(function(s,e,t){typeof st=="object"?pn.exports=st=e($(),r0()):typeof define=="function"&&define.amd?define(["./core","./cipher-core"],e):e(s.CryptoJS)})(st,function(s){return(function(e){var t=s,n=t.lib,a=n.CipherParams,r=t.enc,c=r.Hex,i=t.format,f=i.Hex={stringify:function(h){return h.ciphertext.toString(c)},parse:function(h){var o=c.parse(h);return a.create({ciphertext:o})}}})(),s.format.Hex})});var mn=M((at,gn)=>{(function(s,e,t){typeof at=="object"?gn.exports=at=e($(),w0(),k0(),D0(),r0()):typeof define=="function"&&define.amd?define(["./core","./enc-base64","./md5","./evpkdf","./cipher-core"],e):e(s.CryptoJS)})(at,function(s){return(function(){var e=s,t=e.lib,n=t.BlockCipher,a=e.algo,r=[],c=[],i=[],f=[],h=[],o=[],d=[],x=[],u=[],p=[];(function(){for(var l=[],v=0;v<256;v++)v<128?l[v]=v<<1:l[v]=v<<1^283;for(var C=0,B=0,v=0;v<256;v++){var A=B^B<<1^B<<2^B<<3^B<<4;A=A>>>8^A&255^99,r[C]=A,c[A]=C;var y=l[C],w=l[y],S=l[w],T=l[A]*257^A*16843008;i[C]=T<<24|T>>>8,f[C]=T<<16|T>>>16,h[C]=T<<8|T>>>24,o[C]=T;var T=S*16843009^w*65537^y*257^C*16843008;d[A]=T<<24|T>>>8,x[A]=T<<16|T>>>16,u[A]=T<<8|T>>>24,p[A]=T,C?(C=y^l[l[l[S^y]]],B^=l[l[B]]):C=B=1}})();var g=[0,1,2,4,8,16,32,64,128,27,54],m=a.AES=n.extend({_doReset:function(){var l;if(!(this._nRounds&&this._keyPriorReset===this._key)){for(var v=this._keyPriorReset=this._key,C=v.words,B=v.sigBytes/4,A=this._nRounds=B+6,y=(A+1)*4,w=this._keySchedule=[],S=0;S6&&S%B==4&&(l=r[l>>>24]<<24|r[l>>>16&255]<<16|r[l>>>8&255]<<8|r[l&255]):(l=l<<8|l>>>24,l=r[l>>>24]<<24|r[l>>>16&255]<<16|r[l>>>8&255]<<8|r[l&255],l^=g[S/B|0]<<24),w[S]=w[S-B]^l);for(var T=this._invKeySchedule=[],q=0;q>>24]]^x[r[l>>>16&255]]^u[r[l>>>8&255]]^p[r[l&255]]}}},encryptBlock:function(l,v){this._doCryptBlock(l,v,this._keySchedule,i,f,h,o,r)},decryptBlock:function(l,v){var C=l[v+1];l[v+1]=l[v+3],l[v+3]=C,this._doCryptBlock(l,v,this._invKeySchedule,d,x,u,p,c);var C=l[v+1];l[v+1]=l[v+3],l[v+3]=C},_doCryptBlock:function(l,v,C,B,A,y,w,S){for(var T=this._nRounds,q=l[v]^C[0],E=l[v+1]^C[1],H=l[v+2]^C[2],U=l[v+3]^C[3],k=4,K=1;K>>24]^A[E>>>16&255]^y[H>>>8&255]^w[U&255]^C[k++],L=B[E>>>24]^A[H>>>16&255]^y[U>>>8&255]^w[q&255]^C[k++],I=B[H>>>24]^A[U>>>16&255]^y[q>>>8&255]^w[E&255]^C[k++],b=B[U>>>24]^A[q>>>16&255]^y[E>>>8&255]^w[H&255]^C[k++];q=N,E=L,H=I,U=b}var N=(S[q>>>24]<<24|S[E>>>16&255]<<16|S[H>>>8&255]<<8|S[U&255])^C[k++],L=(S[E>>>24]<<24|S[H>>>16&255]<<16|S[U>>>8&255]<<8|S[q&255])^C[k++],I=(S[H>>>24]<<24|S[U>>>16&255]<<16|S[q>>>8&255]<<8|S[E&255])^C[k++],b=(S[U>>>24]<<24|S[q>>>16&255]<<16|S[E>>>8&255]<<8|S[H&255])^C[k++];l[v]=N,l[v+1]=L,l[v+2]=I,l[v+3]=b},keySize:256/32});e.AES=n._createHelper(m)})(),s.AES})});var Cn=M((it,Bn)=>{(function(s,e,t){typeof it=="object"?Bn.exports=it=e($(),w0(),k0(),D0(),r0()):typeof define=="function"&&define.amd?define(["./core","./enc-base64","./md5","./evpkdf","./cipher-core"],e):e(s.CryptoJS)})(it,function(s){return(function(){var e=s,t=e.lib,n=t.WordArray,a=t.BlockCipher,r=e.algo,c=[57,49,41,33,25,17,9,1,58,50,42,34,26,18,10,2,59,51,43,35,27,19,11,3,60,52,44,36,63,55,47,39,31,23,15,7,62,54,46,38,30,22,14,6,61,53,45,37,29,21,13,5,28,20,12,4],i=[14,17,11,24,1,5,3,28,15,6,21,10,23,19,12,4,26,8,16,7,27,20,13,2,41,52,31,37,47,55,30,40,51,45,33,48,44,49,39,56,34,53,46,42,50,36,29,32],f=[1,2,4,6,8,10,12,14,15,17,19,21,23,25,27,28],h=[{0:8421888,268435456:32768,536870912:8421378,805306368:2,1073741824:512,1342177280:8421890,1610612736:8389122,1879048192:8388608,2147483648:514,2415919104:8389120,2684354560:33280,2952790016:8421376,3221225472:32770,3489660928:8388610,3758096384:0,4026531840:33282,134217728:0,402653184:8421890,671088640:33282,939524096:32768,1207959552:8421888,1476395008:512,1744830464:8421378,2013265920:2,2281701376:8389120,2550136832:33280,2818572288:8421376,3087007744:8389122,3355443200:8388610,3623878656:32770,3892314112:514,4160749568:8388608,1:32768,268435457:2,536870913:8421888,805306369:8388608,1073741825:8421378,1342177281:33280,1610612737:512,1879048193:8389122,2147483649:8421890,2415919105:8421376,2684354561:8388610,2952790017:33282,3221225473:514,3489660929:8389120,3758096385:32770,4026531841:0,134217729:8421890,402653185:8421376,671088641:8388608,939524097:512,1207959553:32768,1476395009:8388610,1744830465:2,2013265921:33282,2281701377:32770,2550136833:8389122,2818572289:514,3087007745:8421888,3355443201:8389120,3623878657:0,3892314113:33280,4160749569:8421378},{0:1074282512,16777216:16384,33554432:524288,50331648:1074266128,67108864:1073741840,83886080:1074282496,100663296:1073758208,117440512:16,134217728:540672,150994944:1073758224,167772160:1073741824,184549376:540688,201326592:524304,218103808:0,234881024:16400,251658240:1074266112,8388608:1073758208,25165824:540688,41943040:16,58720256:1073758224,75497472:1074282512,92274688:1073741824,109051904:524288,125829120:1074266128,142606336:524304,159383552:0,176160768:16384,192937984:1074266112,209715200:1073741840,226492416:540672,243269632:1074282496,260046848:16400,268435456:0,285212672:1074266128,301989888:1073758224,318767104:1074282496,335544320:1074266112,352321536:16,369098752:540688,385875968:16384,402653184:16400,419430400:524288,436207616:524304,452984832:1073741840,469762048:540672,486539264:1073758208,503316480:1073741824,520093696:1074282512,276824064:540688,293601280:524288,310378496:1074266112,327155712:16384,343932928:1073758208,360710144:1074282512,377487360:16,394264576:1073741824,411041792:1074282496,427819008:1073741840,444596224:1073758224,461373440:524304,478150656:0,494927872:16400,511705088:1074266128,528482304:540672},{0:260,1048576:0,2097152:67109120,3145728:65796,4194304:65540,5242880:67108868,6291456:67174660,7340032:67174400,8388608:67108864,9437184:67174656,10485760:65792,11534336:67174404,12582912:67109124,13631488:65536,14680064:4,15728640:256,524288:67174656,1572864:67174404,2621440:0,3670016:67109120,4718592:67108868,5767168:65536,6815744:65540,7864320:260,8912896:4,9961472:256,11010048:67174400,12058624:65796,13107200:65792,14155776:67109124,15204352:67174660,16252928:67108864,16777216:67174656,17825792:65540,18874368:65536,19922944:67109120,20971520:256,22020096:67174660,23068672:67108868,24117248:0,25165824:67109124,26214400:67108864,27262976:4,28311552:65792,29360128:67174400,30408704:260,31457280:65796,32505856:67174404,17301504:67108864,18350080:260,19398656:67174656,20447232:0,21495808:65540,22544384:67109120,23592960:256,24641536:67174404,25690112:65536,26738688:67174660,27787264:65796,28835840:67108868,29884416:67109124,30932992:67174400,31981568:4,33030144:65792},{0:2151682048,65536:2147487808,131072:4198464,196608:2151677952,262144:0,327680:4198400,393216:2147483712,458752:4194368,524288:2147483648,589824:4194304,655360:64,720896:2147487744,786432:2151678016,851968:4160,917504:4096,983040:2151682112,32768:2147487808,98304:64,163840:2151678016,229376:2147487744,294912:4198400,360448:2151682112,425984:0,491520:2151677952,557056:4096,622592:2151682048,688128:4194304,753664:4160,819200:2147483648,884736:4194368,950272:4198464,1015808:2147483712,1048576:4194368,1114112:4198400,1179648:2147483712,1245184:0,1310720:4160,1376256:2151678016,1441792:2151682048,1507328:2147487808,1572864:2151682112,1638400:2147483648,1703936:2151677952,1769472:4198464,1835008:2147487744,1900544:4194304,1966080:64,2031616:4096,1081344:2151677952,1146880:2151682112,1212416:0,1277952:4198400,1343488:4194368,1409024:2147483648,1474560:2147487808,1540096:64,1605632:2147483712,1671168:4096,1736704:2147487744,1802240:2151678016,1867776:4160,1933312:2151682048,1998848:4194304,2064384:4198464},{0:128,4096:17039360,8192:262144,12288:536870912,16384:537133184,20480:16777344,24576:553648256,28672:262272,32768:16777216,36864:537133056,40960:536871040,45056:553910400,49152:553910272,53248:0,57344:17039488,61440:553648128,2048:17039488,6144:553648256,10240:128,14336:17039360,18432:262144,22528:537133184,26624:553910272,30720:536870912,34816:537133056,38912:0,43008:553910400,47104:16777344,51200:536871040,55296:553648128,59392:16777216,63488:262272,65536:262144,69632:128,73728:536870912,77824:553648256,81920:16777344,86016:553910272,90112:537133184,94208:16777216,98304:553910400,102400:553648128,106496:17039360,110592:537133056,114688:262272,118784:536871040,122880:0,126976:17039488,67584:553648256,71680:16777216,75776:17039360,79872:537133184,83968:536870912,88064:17039488,92160:128,96256:553910272,100352:262272,104448:553910400,108544:0,112640:553648128,116736:16777344,120832:262144,124928:537133056,129024:536871040},{0:268435464,256:8192,512:270532608,768:270540808,1024:268443648,1280:2097152,1536:2097160,1792:268435456,2048:0,2304:268443656,2560:2105344,2816:8,3072:270532616,3328:2105352,3584:8200,3840:270540800,128:270532608,384:270540808,640:8,896:2097152,1152:2105352,1408:268435464,1664:268443648,1920:8200,2176:2097160,2432:8192,2688:268443656,2944:270532616,3200:0,3456:270540800,3712:2105344,3968:268435456,4096:268443648,4352:270532616,4608:270540808,4864:8200,5120:2097152,5376:268435456,5632:268435464,5888:2105344,6144:2105352,6400:0,6656:8,6912:270532608,7168:8192,7424:268443656,7680:270540800,7936:2097160,4224:8,4480:2105344,4736:2097152,4992:268435464,5248:268443648,5504:8200,5760:270540808,6016:270532608,6272:270540800,6528:270532616,6784:8192,7040:2105352,7296:2097160,7552:0,7808:268435456,8064:268443656},{0:1048576,16:33555457,32:1024,48:1049601,64:34604033,80:0,96:1,112:34603009,128:33555456,144:1048577,160:33554433,176:34604032,192:34603008,208:1025,224:1049600,240:33554432,8:34603009,24:0,40:33555457,56:34604032,72:1048576,88:33554433,104:33554432,120:1025,136:1049601,152:33555456,168:34603008,184:1048577,200:1024,216:34604033,232:1,248:1049600,256:33554432,272:1048576,288:33555457,304:34603009,320:1048577,336:33555456,352:34604032,368:1049601,384:1025,400:34604033,416:1049600,432:1,448:0,464:34603008,480:33554433,496:1024,264:1049600,280:33555457,296:34603009,312:1,328:33554432,344:1048576,360:1025,376:34604032,392:33554433,408:34603008,424:0,440:34604033,456:1049601,472:1024,488:33555456,504:1048577},{0:134219808,1:131072,2:134217728,3:32,4:131104,5:134350880,6:134350848,7:2048,8:134348800,9:134219776,10:133120,11:134348832,12:2080,13:0,14:134217760,15:133152,2147483648:2048,2147483649:134350880,2147483650:134219808,2147483651:134217728,2147483652:134348800,2147483653:133120,2147483654:133152,2147483655:32,2147483656:134217760,2147483657:2080,2147483658:131104,2147483659:134350848,2147483660:0,2147483661:134348832,2147483662:134219776,2147483663:131072,16:133152,17:134350848,18:32,19:2048,20:134219776,21:134217760,22:134348832,23:131072,24:0,25:131104,26:134348800,27:134219808,28:134350880,29:133120,30:2080,31:134217728,2147483664:131072,2147483665:2048,2147483666:134348832,2147483667:133152,2147483668:32,2147483669:134348800,2147483670:134217728,2147483671:134219808,2147483672:134350880,2147483673:134217760,2147483674:134219776,2147483675:0,2147483676:133120,2147483677:2080,2147483678:131104,2147483679:134350848}],o=[4160749569,528482304,33030144,2064384,129024,8064,504,2147483679],d=r.DES=a.extend({_doReset:function(){for(var g=this._key,m=g.words,l=[],v=0;v<56;v++){var C=c[v]-1;l[v]=m[C>>>5]>>>31-C%32&1}for(var B=this._subKeys=[],A=0;A<16;A++){for(var y=B[A]=[],w=f[A],v=0;v<24;v++)y[v/6|0]|=l[(i[v]-1+w)%28]<<31-v%6,y[4+(v/6|0)]|=l[28+(i[v+24]-1+w)%28]<<31-v%6;y[0]=y[0]<<1|y[0]>>>31;for(var v=1;v<7;v++)y[v]=y[v]>>>(v-1)*4+3;y[7]=y[7]<<5|y[7]>>>27}for(var S=this._invSubKeys=[],v=0;v<16;v++)S[v]=B[15-v]},encryptBlock:function(g,m){this._doCryptBlock(g,m,this._subKeys)},decryptBlock:function(g,m){this._doCryptBlock(g,m,this._invSubKeys)},_doCryptBlock:function(g,m,l){this._lBlock=g[m],this._rBlock=g[m+1],x.call(this,4,252645135),x.call(this,16,65535),u.call(this,2,858993459),u.call(this,8,16711935),x.call(this,1,1431655765);for(var v=0;v<16;v++){for(var C=l[v],B=this._lBlock,A=this._rBlock,y=0,w=0;w<8;w++)y|=h[w][((A^C[w])&o[w])>>>0];this._lBlock=A,this._rBlock=B^y}var S=this._lBlock;this._lBlock=this._rBlock,this._rBlock=S,x.call(this,1,1431655765),u.call(this,8,16711935),u.call(this,2,858993459),x.call(this,16,65535),x.call(this,4,252645135),g[m]=this._lBlock,g[m+1]=this._rBlock},keySize:64/32,ivSize:64/32,blockSize:64/32});function x(g,m){var l=(this._lBlock>>>g^this._rBlock)&m;this._rBlock^=l,this._lBlock^=l<>>g^this._lBlock)&m;this._lBlock^=l,this._rBlock^=l<192.");var l=m.slice(0,2),v=m.length<4?m.slice(0,2):m.slice(2,4),C=m.length<6?m.slice(0,2):m.slice(4,6);this._des1=d.createEncryptor(n.create(l)),this._des2=d.createEncryptor(n.create(v)),this._des3=d.createEncryptor(n.create(C))},encryptBlock:function(g,m){this._des1.encryptBlock(g,m),this._des2.decryptBlock(g,m),this._des3.encryptBlock(g,m)},decryptBlock:function(g,m){this._des3.decryptBlock(g,m),this._des2.encryptBlock(g,m),this._des1.decryptBlock(g,m)},keySize:192/32,ivSize:64/32,blockSize:64/32});e.TripleDES=a._createHelper(p)})(),s.TripleDES})});var En=M((ot,An)=>{(function(s,e,t){typeof ot=="object"?An.exports=ot=e($(),w0(),k0(),D0(),r0()):typeof define=="function"&&define.amd?define(["./core","./enc-base64","./md5","./evpkdf","./cipher-core"],e):e(s.CryptoJS)})(ot,function(s){return(function(){var e=s,t=e.lib,n=t.StreamCipher,a=e.algo,r=a.RC4=n.extend({_doReset:function(){for(var f=this._key,h=f.words,o=f.sigBytes,d=this._S=[],x=0;x<256;x++)d[x]=x;for(var x=0,u=0;x<256;x++){var p=x%o,g=h[p>>>2]>>>24-p%4*8&255;u=(u+d[x]+g)%256;var m=d[x];d[x]=d[u],d[u]=m}this._i=this._j=0},_doProcessBlock:function(f,h){f[h]^=c.call(this)},keySize:256/32,ivSize:0});function c(){for(var f=this._S,h=this._i,o=this._j,d=0,x=0;x<4;x++){h=(h+1)%256,o=(o+f[h])%256;var u=f[h];f[h]=f[o],f[o]=u,d|=f[(f[h]+f[o])%256]<<24-x*8}return this._i=h,this._j=o,d}e.RC4=n._createHelper(r);var i=a.RC4Drop=r.extend({cfg:r.cfg.extend({drop:192}),_doReset:function(){r._doReset.call(this);for(var f=this.cfg.drop;f>0;f--)c.call(this)}});e.RC4Drop=n._createHelper(i)})(),s.RC4})});var bn=M((xt,Dn)=>{(function(s,e,t){typeof xt=="object"?Dn.exports=xt=e($(),w0(),k0(),D0(),r0()):typeof define=="function"&&define.amd?define(["./core","./enc-base64","./md5","./evpkdf","./cipher-core"],e):e(s.CryptoJS)})(xt,function(s){return(function(){var e=s,t=e.lib,n=t.StreamCipher,a=e.algo,r=[],c=[],i=[],f=a.Rabbit=n.extend({_doReset:function(){for(var o=this._key.words,d=this.cfg.iv,x=0;x<4;x++)o[x]=(o[x]<<8|o[x]>>>24)&16711935|(o[x]<<24|o[x]>>>8)&4278255360;var u=this._X=[o[0],o[3]<<16|o[2]>>>16,o[1],o[0]<<16|o[3]>>>16,o[2],o[1]<<16|o[0]>>>16,o[3],o[2]<<16|o[1]>>>16],p=this._C=[o[2]<<16|o[2]>>>16,o[0]&4294901760|o[1]&65535,o[3]<<16|o[3]>>>16,o[1]&4294901760|o[2]&65535,o[0]<<16|o[0]>>>16,o[2]&4294901760|o[3]&65535,o[1]<<16|o[1]>>>16,o[3]&4294901760|o[0]&65535];this._b=0;for(var x=0;x<4;x++)h.call(this);for(var x=0;x<8;x++)p[x]^=u[x+4&7];if(d){var g=d.words,m=g[0],l=g[1],v=(m<<8|m>>>24)&16711935|(m<<24|m>>>8)&4278255360,C=(l<<8|l>>>24)&16711935|(l<<24|l>>>8)&4278255360,B=v>>>16|C&4294901760,A=C<<16|v&65535;p[0]^=v,p[1]^=B,p[2]^=C,p[3]^=A,p[4]^=v,p[5]^=B,p[6]^=C,p[7]^=A;for(var x=0;x<4;x++)h.call(this)}},_doProcessBlock:function(o,d){var x=this._X;h.call(this),r[0]=x[0]^x[5]>>>16^x[3]<<16,r[1]=x[2]^x[7]>>>16^x[5]<<16,r[2]=x[4]^x[1]>>>16^x[7]<<16,r[3]=x[6]^x[3]>>>16^x[1]<<16;for(var u=0;u<4;u++)r[u]=(r[u]<<8|r[u]>>>24)&16711935|(r[u]<<24|r[u]>>>8)&4278255360,o[d+u]^=r[u]},blockSize:128/32,ivSize:64/32});function h(){for(var o=this._X,d=this._C,x=0;x<8;x++)c[x]=d[x];d[0]=d[0]+1295307597+this._b|0,d[1]=d[1]+3545052371+(d[0]>>>0>>0?1:0)|0,d[2]=d[2]+886263092+(d[1]>>>0>>0?1:0)|0,d[3]=d[3]+1295307597+(d[2]>>>0>>0?1:0)|0,d[4]=d[4]+3545052371+(d[3]>>>0>>0?1:0)|0,d[5]=d[5]+886263092+(d[4]>>>0>>0?1:0)|0,d[6]=d[6]+1295307597+(d[5]>>>0>>0?1:0)|0,d[7]=d[7]+3545052371+(d[6]>>>0>>0?1:0)|0,this._b=d[7]>>>0>>0?1:0;for(var x=0;x<8;x++){var u=o[x]+d[x],p=u&65535,g=u>>>16,m=((p*p>>>17)+p*g>>>15)+g*g,l=((u&4294901760)*u|0)+((u&65535)*u|0);i[x]=m^l}o[0]=i[0]+(i[7]<<16|i[7]>>>16)+(i[6]<<16|i[6]>>>16)|0,o[1]=i[1]+(i[0]<<8|i[0]>>>24)+i[7]|0,o[2]=i[2]+(i[1]<<16|i[1]>>>16)+(i[0]<<16|i[0]>>>16)|0,o[3]=i[3]+(i[2]<<8|i[2]>>>24)+i[1]|0,o[4]=i[4]+(i[3]<<16|i[3]>>>16)+(i[2]<<16|i[2]>>>16)|0,o[5]=i[5]+(i[4]<<8|i[4]>>>24)+i[3]|0,o[6]=i[6]+(i[5]<<16|i[5]>>>16)+(i[4]<<16|i[4]>>>16)|0,o[7]=i[7]+(i[6]<<8|i[6]>>>24)+i[5]|0}e.Rabbit=n._createHelper(f)})(),s.Rabbit})});var Sn=M((ct,Fn)=>{(function(s,e,t){typeof ct=="object"?Fn.exports=ct=e($(),w0(),k0(),D0(),r0()):typeof define=="function"&&define.amd?define(["./core","./enc-base64","./md5","./evpkdf","./cipher-core"],e):e(s.CryptoJS)})(ct,function(s){return(function(){var e=s,t=e.lib,n=t.StreamCipher,a=e.algo,r=[],c=[],i=[],f=a.RabbitLegacy=n.extend({_doReset:function(){var o=this._key.words,d=this.cfg.iv,x=this._X=[o[0],o[3]<<16|o[2]>>>16,o[1],o[0]<<16|o[3]>>>16,o[2],o[1]<<16|o[0]>>>16,o[3],o[2]<<16|o[1]>>>16],u=this._C=[o[2]<<16|o[2]>>>16,o[0]&4294901760|o[1]&65535,o[3]<<16|o[3]>>>16,o[1]&4294901760|o[2]&65535,o[0]<<16|o[0]>>>16,o[2]&4294901760|o[3]&65535,o[1]<<16|o[1]>>>16,o[3]&4294901760|o[0]&65535];this._b=0;for(var p=0;p<4;p++)h.call(this);for(var p=0;p<8;p++)u[p]^=x[p+4&7];if(d){var g=d.words,m=g[0],l=g[1],v=(m<<8|m>>>24)&16711935|(m<<24|m>>>8)&4278255360,C=(l<<8|l>>>24)&16711935|(l<<24|l>>>8)&4278255360,B=v>>>16|C&4294901760,A=C<<16|v&65535;u[0]^=v,u[1]^=B,u[2]^=C,u[3]^=A,u[4]^=v,u[5]^=B,u[6]^=C,u[7]^=A;for(var p=0;p<4;p++)h.call(this)}},_doProcessBlock:function(o,d){var x=this._X;h.call(this),r[0]=x[0]^x[5]>>>16^x[3]<<16,r[1]=x[2]^x[7]>>>16^x[5]<<16,r[2]=x[4]^x[1]>>>16^x[7]<<16,r[3]=x[6]^x[3]>>>16^x[1]<<16;for(var u=0;u<4;u++)r[u]=(r[u]<<8|r[u]>>>24)&16711935|(r[u]<<24|r[u]>>>8)&4278255360,o[d+u]^=r[u]},blockSize:128/32,ivSize:64/32});function h(){for(var o=this._X,d=this._C,x=0;x<8;x++)c[x]=d[x];d[0]=d[0]+1295307597+this._b|0,d[1]=d[1]+3545052371+(d[0]>>>0>>0?1:0)|0,d[2]=d[2]+886263092+(d[1]>>>0>>0?1:0)|0,d[3]=d[3]+1295307597+(d[2]>>>0>>0?1:0)|0,d[4]=d[4]+3545052371+(d[3]>>>0>>0?1:0)|0,d[5]=d[5]+886263092+(d[4]>>>0>>0?1:0)|0,d[6]=d[6]+1295307597+(d[5]>>>0>>0?1:0)|0,d[7]=d[7]+3545052371+(d[6]>>>0>>0?1:0)|0,this._b=d[7]>>>0>>0?1:0;for(var x=0;x<8;x++){var u=o[x]+d[x],p=u&65535,g=u>>>16,m=((p*p>>>17)+p*g>>>15)+g*g,l=((u&4294901760)*u|0)+((u&65535)*u|0);i[x]=m^l}o[0]=i[0]+(i[7]<<16|i[7]>>>16)+(i[6]<<16|i[6]>>>16)|0,o[1]=i[1]+(i[0]<<8|i[0]>>>24)+i[7]|0,o[2]=i[2]+(i[1]<<16|i[1]>>>16)+(i[0]<<16|i[0]>>>16)|0,o[3]=i[3]+(i[2]<<8|i[2]>>>24)+i[1]|0,o[4]=i[4]+(i[3]<<16|i[3]>>>16)+(i[2]<<16|i[2]>>>16)|0,o[5]=i[5]+(i[4]<<8|i[4]>>>24)+i[3]|0,o[6]=i[6]+(i[5]<<16|i[5]>>>16)+(i[4]<<16|i[4]>>>16)|0,o[7]=i[7]+(i[6]<<8|i[6]>>>24)+i[5]|0}e.RabbitLegacy=n._createHelper(f)})(),s.RabbitLegacy})});var wn=M((ft,_n)=>{(function(s,e,t){typeof ft=="object"?_n.exports=ft=e($(),w0(),k0(),D0(),r0()):typeof define=="function"&&define.amd?define(["./core","./enc-base64","./md5","./evpkdf","./cipher-core"],e):e(s.CryptoJS)})(ft,function(s){return(function(){var e=s,t=e.lib,n=t.BlockCipher,a=e.algo;let r=16,c=[608135816,2242054355,320440878,57701188,2752067618,698298832,137296536,3964562569,1160258022,953160567,3193202383,887688300,3232508343,3380367581,1065670069,3041331479,2450970073,2306472731],i=[[3509652390,2564797868,805139163,3491422135,3101798381,1780907670,3128725573,4046225305,614570311,3012652279,134345442,2240740374,1667834072,1901547113,2757295779,4103290238,227898511,1921955416,1904987480,2182433518,2069144605,3260701109,2620446009,720527379,3318853667,677414384,3393288472,3101374703,2390351024,1614419982,1822297739,2954791486,3608508353,3174124327,2024746970,1432378464,3864339955,2857741204,1464375394,1676153920,1439316330,715854006,3033291828,289532110,2706671279,2087905683,3018724369,1668267050,732546397,1947742710,3462151702,2609353502,2950085171,1814351708,2050118529,680887927,999245976,1800124847,3300911131,1713906067,1641548236,4213287313,1216130144,1575780402,4018429277,3917837745,3693486850,3949271944,596196993,3549867205,258830323,2213823033,772490370,2760122372,1774776394,2652871518,566650946,4142492826,1728879713,2882767088,1783734482,3629395816,2517608232,2874225571,1861159788,326777828,3124490320,2130389656,2716951837,967770486,1724537150,2185432712,2364442137,1164943284,2105845187,998989502,3765401048,2244026483,1075463327,1455516326,1322494562,910128902,469688178,1117454909,936433444,3490320968,3675253459,1240580251,122909385,2157517691,634681816,4142456567,3825094682,3061402683,2540495037,79693498,3249098678,1084186820,1583128258,426386531,1761308591,1047286709,322548459,995290223,1845252383,2603652396,3431023940,2942221577,3202600964,3727903485,1712269319,422464435,3234572375,1170764815,3523960633,3117677531,1434042557,442511882,3600875718,1076654713,1738483198,4213154764,2393238008,3677496056,1014306527,4251020053,793779912,2902807211,842905082,4246964064,1395751752,1040244610,2656851899,3396308128,445077038,3742853595,3577915638,679411651,2892444358,2354009459,1767581616,3150600392,3791627101,3102740896,284835224,4246832056,1258075500,768725851,2589189241,3069724005,3532540348,1274779536,3789419226,2764799539,1660621633,3471099624,4011903706,913787905,3497959166,737222580,2514213453,2928710040,3937242737,1804850592,3499020752,2949064160,2386320175,2390070455,2415321851,4061277028,2290661394,2416832540,1336762016,1754252060,3520065937,3014181293,791618072,3188594551,3933548030,2332172193,3852520463,3043980520,413987798,3465142937,3030929376,4245938359,2093235073,3534596313,375366246,2157278981,2479649556,555357303,3870105701,2008414854,3344188149,4221384143,3956125452,2067696032,3594591187,2921233993,2428461,544322398,577241275,1471733935,610547355,4027169054,1432588573,1507829418,2025931657,3646575487,545086370,48609733,2200306550,1653985193,298326376,1316178497,3007786442,2064951626,458293330,2589141269,3591329599,3164325604,727753846,2179363840,146436021,1461446943,4069977195,705550613,3059967265,3887724982,4281599278,3313849956,1404054877,2845806497,146425753,1854211946],[1266315497,3048417604,3681880366,3289982499,290971e4,1235738493,2632868024,2414719590,3970600049,1771706367,1449415276,3266420449,422970021,1963543593,2690192192,3826793022,1062508698,1531092325,1804592342,2583117782,2714934279,4024971509,1294809318,4028980673,1289560198,2221992742,1669523910,35572830,157838143,1052438473,1016535060,1802137761,1753167236,1386275462,3080475397,2857371447,1040679964,2145300060,2390574316,1461121720,2956646967,4031777805,4028374788,33600511,2920084762,1018524850,629373528,3691585981,3515945977,2091462646,2486323059,586499841,988145025,935516892,3367335476,2599673255,2839830854,265290510,3972581182,2759138881,3795373465,1005194799,847297441,406762289,1314163512,1332590856,1866599683,4127851711,750260880,613907577,1450815602,3165620655,3734664991,3650291728,3012275730,3704569646,1427272223,778793252,1343938022,2676280711,2052605720,1946737175,3164576444,3914038668,3967478842,3682934266,1661551462,3294938066,4011595847,840292616,3712170807,616741398,312560963,711312465,1351876610,322626781,1910503582,271666773,2175563734,1594956187,70604529,3617834859,1007753275,1495573769,4069517037,2549218298,2663038764,504708206,2263041392,3941167025,2249088522,1514023603,1998579484,1312622330,694541497,2582060303,2151582166,1382467621,776784248,2618340202,3323268794,2497899128,2784771155,503983604,4076293799,907881277,423175695,432175456,1378068232,4145222326,3954048622,3938656102,3820766613,2793130115,2977904593,26017576,3274890735,3194772133,1700274565,1756076034,4006520079,3677328699,720338349,1533947780,354530856,688349552,3973924725,1637815568,332179504,3949051286,53804574,2852348879,3044236432,1282449977,3583942155,3416972820,4006381244,1617046695,2628476075,3002303598,1686838959,431878346,2686675385,1700445008,1080580658,1009431731,832498133,3223435511,2605976345,2271191193,2516031870,1648197032,4164389018,2548247927,300782431,375919233,238389289,3353747414,2531188641,2019080857,1475708069,455242339,2609103871,448939670,3451063019,1395535956,2413381860,1841049896,1491858159,885456874,4264095073,4001119347,1565136089,3898914787,1108368660,540939232,1173283510,2745871338,3681308437,4207628240,3343053890,4016749493,1699691293,1103962373,3625875870,2256883143,3830138730,1031889488,3479347698,1535977030,4236805024,3251091107,2132092099,1774941330,1199868427,1452454533,157007616,2904115357,342012276,595725824,1480756522,206960106,497939518,591360097,863170706,2375253569,3596610801,1814182875,2094937945,3421402208,1082520231,3463918190,2785509508,435703966,3908032597,1641649973,2842273706,3305899714,1510255612,2148256476,2655287854,3276092548,4258621189,236887753,3681803219,274041037,1734335097,3815195456,3317970021,1899903192,1026095262,4050517792,356393447,2410691914,3873677099,3682840055],[3913112168,2491498743,4132185628,2489919796,1091903735,1979897079,3170134830,3567386728,3557303409,857797738,1136121015,1342202287,507115054,2535736646,337727348,3213592640,1301675037,2528481711,1895095763,1721773893,3216771564,62756741,2142006736,835421444,2531993523,1442658625,3659876326,2882144922,676362277,1392781812,170690266,3921047035,1759253602,3611846912,1745797284,664899054,1329594018,3901205900,3045908486,2062866102,2865634940,3543621612,3464012697,1080764994,553557557,3656615353,3996768171,991055499,499776247,1265440854,648242737,3940784050,980351604,3713745714,1749149687,3396870395,4211799374,3640570775,1161844396,3125318951,1431517754,545492359,4268468663,3499529547,1437099964,2702547544,3433638243,2581715763,2787789398,1060185593,1593081372,2418618748,4260947970,69676912,2159744348,86519011,2512459080,3838209314,1220612927,3339683548,133810670,1090789135,1078426020,1569222167,845107691,3583754449,4072456591,1091646820,628848692,1613405280,3757631651,526609435,236106946,48312990,2942717905,3402727701,1797494240,859738849,992217954,4005476642,2243076622,3870952857,3732016268,765654824,3490871365,2511836413,1685915746,3888969200,1414112111,2273134842,3281911079,4080962846,172450625,2569994100,980381355,4109958455,2819808352,2716589560,2568741196,3681446669,3329971472,1835478071,660984891,3704678404,4045999559,3422617507,3040415634,1762651403,1719377915,3470491036,2693910283,3642056355,3138596744,1364962596,2073328063,1983633131,926494387,3423689081,2150032023,4096667949,1749200295,3328846651,309677260,2016342300,1779581495,3079819751,111262694,1274766160,443224088,298511866,1025883608,3806446537,1145181785,168956806,3641502830,3584813610,1689216846,3666258015,3200248200,1692713982,2646376535,4042768518,1618508792,1610833997,3523052358,4130873264,2001055236,3610705100,2202168115,4028541809,2961195399,1006657119,2006996926,3186142756,1430667929,3210227297,1314452623,4074634658,4101304120,2273951170,1399257539,3367210612,3027628629,1190975929,2062231137,2333990788,2221543033,2438960610,1181637006,548689776,2362791313,3372408396,3104550113,3145860560,296247880,1970579870,3078560182,3769228297,1714227617,3291629107,3898220290,166772364,1251581989,493813264,448347421,195405023,2709975567,677966185,3703036547,1463355134,2715995803,1338867538,1343315457,2802222074,2684532164,233230375,2599980071,2000651841,3277868038,1638401717,4028070440,3237316320,6314154,819756386,300326615,590932579,1405279636,3267499572,3150704214,2428286686,3959192993,3461946742,1862657033,1266418056,963775037,2089974820,2263052895,1917689273,448879540,3550394620,3981727096,150775221,3627908307,1303187396,508620638,2975983352,2726630617,1817252668,1876281319,1457606340,908771278,3720792119,3617206836,2455994898,1729034894,1080033504],[976866871,3556439503,2881648439,1522871579,1555064734,1336096578,3548522304,2579274686,3574697629,3205460757,3593280638,3338716283,3079412587,564236357,2993598910,1781952180,1464380207,3163844217,3332601554,1699332808,1393555694,1183702653,3581086237,1288719814,691649499,2847557200,2895455976,3193889540,2717570544,1781354906,1676643554,2592534050,3230253752,1126444790,2770207658,2633158820,2210423226,2615765581,2414155088,3127139286,673620729,2805611233,1269405062,4015350505,3341807571,4149409754,1057255273,2012875353,2162469141,2276492801,2601117357,993977747,3918593370,2654263191,753973209,36408145,2530585658,25011837,3520020182,2088578344,530523599,2918365339,1524020338,1518925132,3760827505,3759777254,1202760957,3985898139,3906192525,674977740,4174734889,2031300136,2019492241,3983892565,4153806404,3822280332,352677332,2297720250,60907813,90501309,3286998549,1016092578,2535922412,2839152426,457141659,509813237,4120667899,652014361,1966332200,2975202805,55981186,2327461051,676427537,3255491064,2882294119,3433927263,1307055953,942726286,933058658,2468411793,3933900994,4215176142,1361170020,2001714738,2830558078,3274259782,1222529897,1679025792,2729314320,3714953764,1770335741,151462246,3013232138,1682292957,1483529935,471910574,1539241949,458788160,3436315007,1807016891,3718408830,978976581,1043663428,3165965781,1927990952,4200891579,2372276910,3208408903,3533431907,1412390302,2931980059,4132332400,1947078029,3881505623,4168226417,2941484381,1077988104,1320477388,886195818,18198404,3786409e3,2509781533,112762804,3463356488,1866414978,891333506,18488651,661792760,1628790961,3885187036,3141171499,876946877,2693282273,1372485963,791857591,2686433993,3759982718,3167212022,3472953795,2716379847,445679433,3561995674,3504004811,3574258232,54117162,3331405415,2381918588,3769707343,4154350007,1140177722,4074052095,668550556,3214352940,367459370,261225585,2610173221,4209349473,3468074219,3265815641,314222801,3066103646,3808782860,282218597,3406013506,3773591054,379116347,1285071038,846784868,2669647154,3771962079,3550491691,2305946142,453669953,1268987020,3317592352,3279303384,3744833421,2610507566,3859509063,266596637,3847019092,517658769,3462560207,3443424879,370717030,4247526661,2224018117,4143653529,4112773975,2788324899,2477274417,1456262402,2901442914,1517677493,1846949527,2295493580,3734397586,2176403920,1280348187,1908823572,3871786941,846861322,1172426758,3287448474,3383383037,1655181056,3139813346,901632758,1897031941,2986607138,3066810236,3447102507,1393639104,373351379,950779232,625454576,3124240540,4148612726,2007998917,544563296,2244738638,2330496472,2058025392,1291430526,424198748,50039436,29584100,3605783033,2429876329,2791104160,1057563949,3255363231,3075367218,3463963227,1469046755,985887462]];var f={pbox:[],sbox:[]};function h(p,g){let m=g>>24&255,l=g>>16&255,v=g>>8&255,C=g&255,B=p.sbox[0][m]+p.sbox[1][l];return B=B^p.sbox[2][v],B=B+p.sbox[3][C],B}function o(p,g,m){let l=g,v=m,C;for(let B=0;B1;--B)l=l^p.pbox[B],v=h(p,l)^v,C=l,l=v,v=C;return C=l,l=v,v=C,v=v^p.pbox[1],l=l^p.pbox[0],{left:l,right:v}}function x(p,g,m){for(let A=0;A<4;A++){p.sbox[A]=[];for(let y=0;y<256;y++)p.sbox[A][y]=i[A][y]}let l=0;for(let A=0;A=m&&(l=0);let v=0,C=0,B=0;for(let A=0;A{(function(s,e,t){typeof dt=="object"?kn.exports=dt=e($(),se(),Fr(),_r(),w0(),Pr(),k0(),jt(),Ve(),Ur(),Xt(),Or(),Kr(),Wr(),Me(),$r(),D0(),r0(),Zr(),Qr(),en(),rn(),sn(),on(),cn(),dn(),un(),vn(),yn(),mn(),Cn(),En(),bn(),Sn(),wn()):typeof define=="function"&&define.amd?define(["./core","./x64-core","./lib-typedarrays","./enc-utf16","./enc-base64","./enc-base64url","./md5","./sha1","./sha256","./sha224","./sha512","./sha384","./sha3","./ripemd160","./hmac","./pbkdf2","./evpkdf","./cipher-core","./mode-cfb","./mode-ctr","./mode-ctr-gladman","./mode-ofb","./mode-ecb","./pad-ansix923","./pad-iso10126","./pad-iso97971","./pad-zeropadding","./pad-nopadding","./format-hex","./aes","./tripledes","./rc4","./rabbit","./rabbit-legacy","./blowfish"],e):s.CryptoJS=e(s.CryptoJS)})(dt,function(s){return s})});var Pn=M(()=>{});var Rn=M((Hn,pt)=>{"use strict";var Qt=(()=>{var s=typeof document<"u"?document.currentScript?.src:void 0;return(async function(e={}){var t,n=e,a=typeof window=="object",r=typeof WorkerGlobalScope<"u",c=typeof process=="object"&&process.versions?.node&&process.type!="renderer",i=[],f="./this.program",h=(D,R)=>{throw R};typeof __filename<"u"?s=__filename:r&&(s=self.location.href);var o="";function d(D){return n.locateFile?n.locateFile(D,o):o+D}var x,u;if(c){var p=Pn();o=__dirname+"/",u=D=>{D=C(D)?new URL(D):D;var R=p.readFileSync(D);return R},x=async(D,R=!0)=>{D=C(D)?new URL(D):D;var O=p.readFileSync(D,R?void 0:"utf8");return O},process.argv.length>1&&(f=process.argv[1].replace(/\\/g,"/")),i=process.argv.slice(2),h=(D,R)=>{throw process.exitCode=D,R}}else if(a||r){try{o=new URL(".",s).href}catch{}r&&(u=D=>{var R=new XMLHttpRequest;return R.open("GET",D,!1),R.responseType="arraybuffer",R.send(null),new Uint8Array(R.response)}),x=async D=>{if(C(D))return new Promise((O,G)=>{var j=new XMLHttpRequest;j.open("GET",D,!0),j.responseType="arraybuffer",j.onload=()=>{if(j.status==200||j.status==0&&j.response){O(j.response);return}G(j.status)},j.onerror=G,j.send(null)});var R=await fetch(D,{credentials:"same-origin"});if(R.ok)return R.arrayBuffer();throw new Error(R.status+" : "+R.url)}}var g=console.log.bind(console),m=console.error.bind(console),l,v=!1,C=D=>D.startsWith("file://"),B,A,y,w,S,T,q,E,H,U,k,K,N,L=!1;function I(){var D=y.buffer;n.HEAP8=w=new Int8Array(D),T=new Int16Array(D),n.HEAPU8=S=new Uint8Array(D),q=new Uint16Array(D),n.HEAP32=E=new Int32Array(D),n.HEAPU32=H=new Uint32Array(D),U=new Float32Array(D),k=new Float64Array(D),K=new BigInt64Array(D),N=new BigUint64Array(D)}function b(){if(n.preRun)for(typeof n.preRun=="function"&&(n.preRun=[n.preRun]);n.preRun.length;)x0(n.preRun.shift());F0(o0)}function _(){L=!0,U0.b()}function P(){if(n.postRun)for(typeof n.postRun=="function"&&(n.postRun=[n.postRun]);n.postRun.length;)R0(n.postRun.shift());F0(M0)}var F=0,X=null;function Y(D){F++,n.monitorRunDependencies?.(F)}function s0(D){if(F--,n.monitorRunDependencies?.(F),F==0&&X){var R=X;X=null,R()}}function W(D){n.onAbort?.(D),D="Aborted("+D+")",m(D),v=!0,D+=". Build with -sASSERTIONS for more info.";var R=new WebAssembly.RuntimeError(D);throw A?.(R),R}var g0;function b0(){return d("orlp-ed25519.wasm")}function X0(D){if(D==g0&&l)return new Uint8Array(l);if(u)return u(D);throw"both async and sync fetching of the wasm failed"}async function P0(D){if(!l)try{var R=await x(D);return new Uint8Array(R)}catch{}return X0(D)}async function d0(D,R){try{var O=await P0(D),G=await WebAssembly.instantiate(O,R);return G}catch(j){m(`failed to asynchronously prepare wasm: ${j}`),W(j)}}async function i0(D,R,O){if(!D&&typeof WebAssembly.instantiateStreaming=="function"&&!C(R)&&!c)try{var G=fetch(R,{credentials:"same-origin"}),j=await WebAssembly.instantiateStreaming(G,O);return j}catch(J){m(`wasm streaming compile failed: ${J}`),m("falling back to ArrayBuffer instantiation")}return d0(R,O)}function W0(){return{a:Be}}async function H0(){function D(J,Q){return U0=J.exports,y=U0.a,I(),Pt(U0),s0("wasm-instantiate"),U0}Y("wasm-instantiate");function R(J){return D(J.instance)}var O=W0();if(n.instantiateWasm)return new Promise((J,Q)=>{n.instantiateWasm(O,(e0,S0)=>{J(D(e0,S0))})});g0??=b0();var G=await i0(l,g0,O),j=R(G);return j}class Z0{name="ExitStatus";constructor(R){this.message=`Program terminated with exit(${R})`,this.status=R}}var F0=D=>{for(;D.length>0;)D.shift()(n)},M0=[],R0=D=>M0.push(D),o0=[],x0=D=>o0.push(D),h0=!0,I0=D=>Y0(D),ce=()=>me(),m0=D=>{var R=n["_"+D];return R},T0=(D,R)=>{w.set(D,R)},St=D=>{for(var R=0,O=0;O=55296&&G<=57343?(R+=4,++O):R+=3}return R},fe=(D,R,O,G)=>{if(!(G>0))return 0;for(var j=O,J=O+G-1,Q=0;Q=J)break;R[O++]=e0}else if(e0<=2047){if(O+1>=J)break;R[O++]=192|e0>>6,R[O++]=128|e0&63}else if(e0<=65535){if(O+2>=J)break;R[O++]=224|e0>>12,R[O++]=128|e0>>6&63,R[O++]=128|e0&63}else{if(O+3>=J)break;R[O++]=240|e0>>18,R[O++]=128|e0>>12&63,R[O++]=128|e0>>6&63,R[O++]=128|e0&63,Q++}}return R[O]=0,O-j},de=(D,R,O)=>fe(D,S,R,O),B0=D=>ge(D),q0=D=>{var R=St(D)+1,O=B0(R);return de(D,O,R),O},le=typeof TextDecoder<"u"?new TextDecoder:void 0,ue=(D,R=0,O=NaN)=>{for(var G=R+O,j=R;D[j]&&!(j>=G);)++j;if(j-R>16&&D.buffer&&le)return le.decode(D.subarray(R,j));for(var J="";R>10,56320|V0&1023)}}return J},he=(D,R)=>D?ue(S,D,R):"",ve=(D,R,O,G,j)=>{var J={string:l0=>{var J0=0;return l0!=null&&l0!==0&&(J0=q0(l0)),J0},array:l0=>{var J0=B0(l0.length);return T0(l0,J0),J0}};function Q(l0){return R==="string"?he(l0):R==="boolean"?!!l0:l0}var e0=m0(D),S0=[],V0=0;if(G)for(var z0=0;z0{var j=!O||O.every(Q=>Q==="number"||Q==="boolean"),J=R!=="string";return J&&j&&!G?m0(D):(...Q)=>ve(D,R,O,Q,G)};n.noExitRuntime&&(h0=n.noExitRuntime),n.print&&(g=n.print),n.printErr&&(m=n.printErr),n.wasmBinary&&(l=n.wasmBinary),n.arguments&&(i=n.arguments),n.thisProgram&&(f=n.thisProgram),n.ccall=ve,n.cwrap=_t;var pe,wt,ye,kt,Y0,ge,me;function Pt(D){n._orlp_derive_public_key=pe=D.c,n._orlp_validate_keypair=wt=D.d,n._orlp_sign=ye=D.e,n._orlp_verify=kt=D.f,Y0=D.g,ge=D.h,me=D.i}var Be={},U0=await H0();function Q0(){if(F>0){X=Q0;return}if(b(),F>0){X=Q0;return}function D(){n.calledRun=!0,!v&&(_(),B?.(n),n.onRuntimeInitialized?.(),P())}n.setStatus?(n.setStatus("Running..."),setTimeout(()=>{setTimeout(()=>n.setStatus(""),1),D()},1)):D()}function Ce(){if(n.preInit)for(typeof n.preInit=="function"&&(n.preInit=[n.preInit]);n.preInit.length>0;)n.preInit.shift()()}return Ce(),Q0(),L?t=n:t=new Promise((D,R)=>{B=D,A=R}),t})})();typeof Hn=="object"&&typeof pt=="object"?(pt.exports=Qt,pt.exports.default=Qt):typeof define=="function"&&define.amd&&define([],()=>Qt)});var Gt={};In(Gt,{CURVE:()=>cr,ExtendedPoint:()=>y0,Point:()=>y0,etc:()=>E0,getPublicKey:()=>ts,getPublicKeyAsync:()=>es,sign:()=>ns,signAsync:()=>rs,utils:()=>as,verify:()=>ne,verifyAsync:()=>ss});var cr={p:0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffedn,n:0x1000000000000000000000000000000014def9dea2f79cd65812631a5cf5d3edn,h:8n,a:0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffecn,d:0x52036cee2b6ffe738cc740797779e89800700a4d4141d8ab75eb4dca135978a3n,Gx:0x216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51an,Gy:0x6666666666666666666666666666666666666666666666666666666666666658n},{p:a0,n:Ae,Gx:rr,Gy:nr,a:Tt,d:qt}=cr,Gn=8n,p0=32,te=64,u0=(s="")=>{throw new Error(s)},jn=s=>typeof s=="bigint",fr=s=>typeof s=="string",Xn=s=>s instanceof Uint8Array||ArrayBuffer.isView(s)&&s.constructor.name==="Uint8Array",N0=(s,e)=>!Xn(s)||typeof e=="number"&&e>0&&s.length!==e?u0("Uint8Array expected"):s,Fe=s=>new Uint8Array(s),zt=s=>Uint8Array.from(s),dr=(s,e)=>s.toString(16).padStart(e,"0"),Ot=s=>Array.from(N0(s)).map(e=>dr(e,2)).join(""),C0={_0:48,_9:57,A:65,F:70,a:97,f:102},sr=s=>{if(s>=C0._0&&s<=C0._9)return s-C0._0;if(s>=C0.A&&s<=C0.F)return s-(C0.A-10);if(s>=C0.a&&s<=C0.f)return s-(C0.a-10)},Nt=s=>{let e="hex invalid";if(!fr(s))return u0(e);let t=s.length,n=t/2;if(t%2)return u0(e);let a=Fe(n);for(let r=0,c=0;rN0(fr(s)?Nt(s):zt(N0(s)),e),lr=()=>globalThis?.crypto,Zn=()=>lr()?.subtle??u0("crypto.subtle must be defined"),re=(...s)=>{let e=Fe(s.reduce((n,a)=>n+N0(a).length,0)),t=0;return s.forEach(n=>{e.set(n,t),t+=n.length}),e},ur=(s=p0)=>lr().getRandomValues(Fe(s)),Ee=BigInt,O0=(s,e,t,n="bad number: out of range")=>jn(s)&&e<=s&&s{let t=s%e;return t>=0n?t:e+t},hr=s=>z(s,Ae),vr=(s,e)=>{(s===0n||e<=0n)&&u0("no inverse n="+s+" mod="+e);let t=z(s,e),n=e,a=0n,r=1n,c=1n,i=0n;for(;t!==0n;){let f=n/t,h=n%t,o=a-c*f,d=r-i*f;n=t,t=h,a=c,r=i,c=o,i=d}return n===1n?z(a,e):u0("no inverse")},Yn=s=>{let e=E0[s];return typeof e!="function"&&u0("hashes."+s+" not set"),e},ar=s=>s instanceof y0?s:u0("Point expected"),Ut=2n**256n,y0=class s{static BASE;static ZERO;ex;ey;ez;et;constructor(e,t,n,a){let r=Ut;this.ex=O0(e,0n,r),this.ey=O0(t,0n,r),this.ez=O0(n,1n,r),this.et=O0(a,0n,r),Object.freeze(this)}static fromAffine(e){return new s(e.x,e.y,1n,z(e.x*e.y))}static fromBytes(e,t=!1){let n=qt,a=zt(N0(e,p0)),r=e[31];a[31]=r&-129;let c=Kt(a);O0(c,0n,t?Ut:a0);let f=z(c*c),h=z(f-1n),o=z(n*f+1n),{isValid:d,value:x}=Jn(h,o);d||u0("bad point: y not sqrt");let u=(x&1n)===1n,p=(r&128)!==0;return!t&&x===0n&&p&&u0("bad point: x==0, isLastByteOdd"),p!==u&&(x=z(-x)),new s(x,c,1n,z(x*c))}assertValidity(){let e=Tt,t=qt,n=this;if(n.is0())throw new Error("bad point: ZERO");let{ex:a,ey:r,ez:c,et:i}=n,f=z(a*a),h=z(r*r),o=z(c*c),d=z(o*o),x=z(f*e),u=z(o*z(x+h)),p=z(d+z(t*z(f*h)));if(u!==p)throw new Error("bad point: equation left != right (1)");let g=z(a*r),m=z(c*i);if(g!==m)throw new Error("bad point: equation left != right (2)");return this}equals(e){let{ex:t,ey:n,ez:a}=this,{ex:r,ey:c,ez:i}=ar(e),f=z(t*i),h=z(r*a),o=z(n*i),d=z(c*a);return f===h&&o===d}is0(){return this.equals($0)}negate(){return new s(z(-this.ex),this.ey,this.ez,z(-this.et))}double(){let{ex:e,ey:t,ez:n}=this,a=Tt,r=z(e*e),c=z(t*t),i=z(2n*z(n*n)),f=z(a*r),h=e+t,o=z(z(h*h)-r-c),d=f+c,x=d-i,u=f-c,p=z(o*x),g=z(d*u),m=z(o*u),l=z(x*d);return new s(p,g,l,m)}add(e){let{ex:t,ey:n,ez:a,et:r}=this,{ex:c,ey:i,ez:f,et:h}=ar(e),o=Tt,d=qt,x=z(t*c),u=z(n*i),p=z(r*d*h),g=z(a*f),m=z((t+n)*(c+i)-x-u),l=z(g-p),v=z(g+p),C=z(u-o*x),B=z(m*l),A=z(v*C),y=z(m*C),w=z(l*v);return new s(B,A,w,y)}multiply(e,t=!0){if(!t&&(e===0n||this.is0()))return $0;if(O0(e,1n,Ae),e===1n)return this;if(this.equals(A0))return xs(e).p;let n=$0,a=A0;for(let r=this;e>0n;r=r.double(),e>>=1n)e&1n?n=n.add(r):t&&(a=a.add(r));return n}toAffine(){let{ex:e,ey:t,ez:n}=this;if(this.equals($0))return{x:0n,y:1n};let a=vr(n,a0);return z(n*a)!==1n&&u0("invalid inverse"),{x:z(e*a),y:z(t*a)}}toBytes(){let{x:e,y:t}=this.assertValidity().toAffine(),n=pr(t);return n[31]|=e&1n?128:0,n}toHex(){return Ot(this.toBytes())}clearCofactor(){return this.multiply(Ee(Gn),!1)}isSmallOrder(){return this.clearCofactor().is0()}isTorsionFree(){let e=this.multiply(Ae/2n,!1).double();return Ae%2n&&(e=e.add(this)),e.is0()}static fromHex(e,t){return s.fromBytes(_0(e),t)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}toRawBytes(){return this.toBytes()}},A0=new y0(rr,nr,1n,z(rr*nr)),$0=new y0(0n,1n,1n,0n);y0.BASE=A0;y0.ZERO=$0;var pr=s=>Nt(dr(O0(s,0n,Ut),te)).reverse(),Kt=s=>Ee("0x"+Ot(zt(N0(s)).reverse())),v0=(s,e)=>{let t=s;for(;e-- >0n;)t*=t,t%=a0;return t},Qn=s=>{let t=s*s%a0*s%a0,n=v0(t,2n)*t%a0,a=v0(n,1n)*s%a0,r=v0(a,5n)*a%a0,c=v0(r,10n)*r%a0,i=v0(c,20n)*c%a0,f=v0(i,40n)*i%a0,h=v0(f,80n)*f%a0,o=v0(h,80n)*f%a0,d=v0(o,10n)*r%a0;return{pow_p_5_8:v0(d,2n)*s%a0,b2:t}},ir=0x2b8324804fc1df0b2b4d00993dfbd7a72f431806ad2fe478c4ee1b274a0ea0b0n,Jn=(s,e)=>{let t=z(e*e*e),n=z(t*t*e),a=Qn(s*n).pow_p_5_8,r=z(s*t*a),c=z(e*r*r),i=r,f=z(r*ir),h=c===s,o=c===z(-s),d=c===z(-s*ir);return h&&(r=i),(o||d)&&(r=f),(z(r)&1n)===1n&&(r=z(-r)),{isValid:h||o,value:r}},De=s=>hr(Kt(s)),Lt=(...s)=>E0.sha512Async(...s),Wt=(...s)=>Yn("sha512Sync")(...s),yr=s=>{let e=s.slice(0,p0);e[0]&=248,e[31]&=127,e[31]|=64;let t=s.slice(p0,te),n=De(e),a=A0.multiply(n),r=a.toBytes();return{head:e,prefix:t,scalar:n,point:a,pointBytes:r}},Mt=s=>Lt(_0(s,p0)).then(yr),It=s=>yr(Wt(_0(s,p0))),es=s=>Mt(s).then(e=>e.pointBytes),ts=s=>It(s).pointBytes,gr=s=>Lt(s.hashable).then(s.finish),mr=s=>s.finish(Wt(s.hashable)),Br=(s,e,t)=>{let{pointBytes:n,scalar:a}=s,r=De(e),c=A0.multiply(r).toBytes();return{hashable:re(c,n,t),finish:h=>{let o=hr(r+De(h)*a);return N0(re(c,pr(o)),te)}}},rs=async(s,e)=>{let t=_0(s),n=await Mt(e),a=await Lt(n.prefix,t);return gr(Br(n,a,t))},ns=(s,e)=>{let t=_0(s),n=It(e),a=Wt(n.prefix,t);return mr(Br(n,a,t))},$t={zip215:!0},Cr=(s,e,t,n=$t)=>{s=_0(s,te),e=_0(e),t=_0(t,p0);let{zip215:a}=n,r,c,i,f,h=Uint8Array.of();try{r=y0.fromHex(t,a),c=y0.fromHex(s.slice(0,p0),a),i=Kt(s.slice(p0,te)),f=A0.multiply(i,!1),h=re(c.toBytes(),r.toBytes(),e)}catch{}return{hashable:h,finish:d=>{if(f==null||!a&&r.isSmallOrder())return!1;let x=De(d);return c.add(r.multiply(x,!1)).add(f.negate()).clearCofactor().is0()}}},ss=async(s,e,t,n=$t)=>gr(Cr(s,e,t,n)),ne=(s,e,t,n=$t)=>mr(Cr(s,e,t,n)),E0={sha512Async:async(...s)=>{let e=Zn(),t=re(...s);return Fe(await e.digest("SHA-512",t.buffer))},sha512Sync:void 0,bytesToHex:Ot,hexToBytes:Nt,concatBytes:re,mod:z,invert:vr,randomBytes:ur},as={getExtendedPublicKeyAsync:Mt,getExtendedPublicKey:It,randomPrivateKey:()=>ur(p0),precompute:(s=8,e=A0)=>(e.multiply(3n),e)},be=8,is=256,Ar=Math.ceil(is/be)+1,Vt=2**(be-1),os=()=>{let s=[],e=A0,t=e;for(let n=0;n{let t=e.negate();return s?t:e},xs=s=>{let e=or||(or=os()),t=$0,n=A0,a=2**be,r=a,c=Ee(a-1),i=Ee(be);for(let f=0;f>=i,h>Vt&&(h-=r,s+=1n);let o=f*Vt,d=o,x=o+Math.abs(h)-1,u=f%2!==0,p=h<0;h===0?n=n.add(xr(u,e[d])):t=t.add(xr(p,e[x]))}return{p:t,f:n}};var Jt=tr(lt());var ut=(a=>(a[a.TransportFlood=0]="TransportFlood",a[a.Flood=1]="Flood",a[a.Direct=2]="Direct",a[a.TransportDirect=3]="TransportDirect",a))(ut||{}),c0=(u=>(u[u.Request=0]="Request",u[u.Response=1]="Response",u[u.TextMessage=2]="TextMessage",u[u.Ack=3]="Ack",u[u.Advert=4]="Advert",u[u.GroupText=5]="GroupText",u[u.GroupData=6]="GroupData",u[u.AnonRequest=7]="AnonRequest",u[u.Path=8]="Path",u[u.Trace=9]="Trace",u[u.Multipart=10]="Multipart",u[u.Control=11]="Control",u[u.RawCustom=15]="RawCustom",u))(c0||{}),ht=(t=>(t[t.NodeDiscoverReq=128]="NodeDiscoverReq",t[t.NodeDiscoverResp=144]="NodeDiscoverResp",t))(ht||{}),f0=(a=>(a[a.Version1=0]="Version1",a[a.Version2=1]="Version2",a[a.Version3=2]="Version3",a[a.Version4=3]="Version4",a))(f0||{}),ae=(r=>(r[r.Unknown=0]="Unknown",r[r.ChatNode=1]="ChatNode",r[r.Repeater=2]="Repeater",r[r.RoomServer=3]="RoomServer",r[r.Sensor=4]="Sensor",r))(ae||{}),Zt=(a=>(a[a.HasLocation=16]="HasLocation",a[a.HasFeature1=32]="HasFeature1",a[a.HasFeature2=64]="HasFeature2",a[a.HasName=128]="HasName",a))(Zt||{}),vt=(r=>(r[r.GetStats=1]="GetStats",r[r.Keepalive=2]="Keepalive",r[r.GetTelemetryData=3]="GetTelemetryData",r[r.GetMinMaxAvgData=4]="GetMinMaxAvgData",r[r.GetAccessList=5]="GetAccessList",r))(vt||{});var t0=tr(lt());function n0(s){return s.toString(16).padStart(2,"0").toUpperCase()}function V(s){return Array.from(s).map(n0).join("")}function G0(s,e=8){return(s>>>0).toString(16).padStart(e,"0").toUpperCase()}function Z(s){let e=s.replace(/\s/g,"").toUpperCase();if(!/^[0-9A-F]*$/.test(e))throw new Error("Invalid hex string: invalid characters at position 0");if(e.length%2!==0)throw new Error("Invalid hex string: odd length");let t=new Uint8Array(e.length/2);for(let n=0;n=0&&(v=v.substring(0,C));let B=v.indexOf(": "),A,y;if(B>0&&B<50){let w=v.substring(0,B);/[:\[\]]/.test(w)?y=v:(A=w,y=v.substring(B+2))}else y=v;return{success:!0,data:{timestamp:p,flags:g,sender:A,message:y}}}catch(a){return{success:!1,error:a instanceof Error?a.message:"Decryption failed"}}}static calculateChannelHash(e){let t=(0,t0.SHA256)(t0.enc.Hex.parse(e));return Z(t.toString(t0.enc.Hex))[0].toString(16).padStart(2,"0")}};var ie=class{constructor(e){this.nodeKeys=new Map;this.channelHashToKeys=new Map;e?.channelSecrets&&this.addChannelSecrets(e.channelSecrets),e?.nodeKeys&&Object.entries(e.nodeKeys).forEach(([t,n])=>{this.addNodeKey(t,n)})}addNodeKey(e,t){let n=e.toUpperCase();this.nodeKeys.set(n,t)}hasChannelKey(e){let t=e.toLowerCase();return this.channelHashToKeys.has(t)}hasNodeKey(e){let t=e.toUpperCase();return this.nodeKeys.has(t)}getChannelKeys(e){let t=e.toLowerCase();return this.channelHashToKeys.get(t)||[]}getNodeKey(e){let t=e.toUpperCase();return this.nodeKeys.get(t)}addChannelSecrets(e){for(let t of e){let n=K0.calculateChannelHash(t).toLowerCase();this.channelHashToKeys.has(n)||this.channelHashToKeys.set(n,[]),this.channelHashToKeys.get(n).push(t)}}};function Yt(s){switch(s){case 1:return"Flood";case 2:return"Direct";case 0:return"TransportFlood";case 3:return"TransportDirect";default:return`Unknown (${s})`}}function L0(s){switch(s){case 15:return"RawCustom";case 9:return"Trace";case 4:return"Advert";case 5:return"GroupText";case 6:return"GroupData";case 0:return"Request";case 1:return"Response";case 2:return"TextMessage";case 7:return"AnonRequest";case 3:return"Ack";case 8:return"Path";case 10:return"Multipart";case 11:return"Control";default:return`Unknown (0x${s.toString(16)})`}}function cs(s){switch(s){case 0:return"Version 1";case 1:return"Version 2";case 2:return"Version 3";case 3:return"Version 4";default:return`Unknown (${s})`}}function oe(s){switch(s){case 0:return"Unknown";case 1:return"Chat Node";case 2:return"Repeater";case 3:return"Room Server";case 4:return"Sensor";default:return`Unknown (${s})`}}function fs(s){switch(s){case 1:return"Get Stats";case 2:return"Keepalive (deprecated)";case 3:return"Get Telemetry Data";case 4:return"Get Min/Max/Avg Data";case 5:return"Get Access List";default:return`Unknown (${s})`}}function ds(s){switch(s){case 128:return"Node Discover Request";case 144:return"Node Discover Response";default:return`Unknown (0x${s.toString(16)})`}}var ls=Rn();async function Tn(){return await ls()}async function qn(s){let e=await Tn(),t=Z(s);if(t.length!==64)throw new Error(`Invalid private key length: expected 64 bytes, got ${t.length}`);let n=1024,a=1088;if(e.HEAPU8.set(t,n),e.ccall("orlp_derive_public_key","number",["number","number"],[a,n])!==0)throw new Error("orlp key derivation failed: invalid private key");let c=new Uint8Array(32);return c.set(e.HEAPU8.subarray(a,a+32)),V(c)}async function Un(s,e){try{let t=await Tn(),n=Z(s),a=Z(e);if(n.length!==64||a.length!==32)return!1;let r=2048,c=2112;return t.HEAPU8.set(n,r),t.HEAPU8.set(a,c),t.ccall("orlp_validate_keypair","number",["number","number"],[c,r])===1}catch{return!1}}async function us(s){if(typeof globalThis<"u"&&globalThis.crypto&&globalThis.crypto.subtle){let e=await globalThis.crypto.subtle.digest("SHA-512",s);return new Uint8Array(e)}if(typeof ee<"u")try{let{createHash:e}=Se();return e("sha512").update(s).digest()}catch{}throw new Error("No SHA-512 implementation available")}function hs(s){if(typeof ee<"u")try{let{createHash:e}=Se();return e("sha512").update(s).digest()}catch{}try{let e=lt(),t=e.lib.WordArray.create(s),n=e.SHA512(t),a=new Uint8Array(64);for(let r=0;r<16;r++){let c=n.words[r]||0;a[r*4]=c>>>24&255,a[r*4+1]=c>>>16&255,a[r*4+2]=c>>>8&255,a[r*4+3]=c&255}return a}catch{throw new Error("No SHA-512 implementation available for synchronous operation")}}E0.sha512Async=us;try{E0.sha512Sync=hs}catch(s){console.debug("Could not set up synchronous SHA-512:",s)}var yt=class{static async verifyAdvertisementSignature(e,t,n,a){try{let r=Z(e),c=Z(t),i=Z(a),f=this.constructAdvertSignedMessage(e,n,i);return await ne(c,f,r)}catch(r){return console.error("Ed25519 signature verification failed:",r),!1}}static constructAdvertSignedMessage(e,t,n){let a=Z(e),r=new Uint8Array(4);r[0]=t&255,r[1]=t>>8&255,r[2]=t>>16&255,r[3]=t>>24&255;let c=new Uint8Array(36+n.length);return c.set(a,0),c.set(r,32),c.set(n,36),c}static getSignedMessageDescription(e,t,n){return`Public Key: ${e} + Timestamp: ${t} (${new Date(t*1e3).toISOString()}) + App Data: ${n}`}static getSignedMessageHex(e,t,n){let a=Z(n),r=this.constructAdvertSignedMessage(e,t,a);return V(r)}static async derivePublicKey(e){try{let t=Z(e);if(t.length!==64)throw new Error(`Invalid private key length: expected 64 bytes, got ${t.length}`);return await qn(e)}catch(t){throw new Error(`Failed to derive public key: ${t instanceof Error?t.message:"Unknown error"}`)}}static derivePublicKeySync(e){try{let t=Z(e);throw t.length!==64?new Error(`Invalid private key length: expected 64 bytes, got ${t.length}`):new Error("Synchronous key derivation not supported with WASM. Use derivePublicKey() instead.")}catch(t){throw new Error(`Failed to derive public key: ${t instanceof Error?t.message:"Unknown error"}`)}}static async validateKeyPair(e,t){try{return await Un(e,t)}catch{return!1}}};var xe=class{static decode(e,t){try{if(e.length<101){let x={type:4,version:0,isValid:!1,errors:["Advertisement payload too short"],publicKey:"",timestamp:0,signature:"",appData:{flags:0,deviceRole:1,hasLocation:!1,hasName:!1}};return t?.includeSegments&&(x.segments=[{name:"Invalid Advert Data",description:"Advert payload too short (minimum 101 bytes required)",startByte:t.segmentOffset||0,endByte:(t.segmentOffset||0)+e.length-1,value:V(e)}]),x}let n=[],a=t?.segmentOffset||0,r=0,c=V(e.subarray(r,r+32));t?.includeSegments&&n.push({name:"Public Key",description:"Ed25519 public key",startByte:a+r,endByte:a+r+31,value:c}),r+=32;let i=this.readUint32LE(e,r);if(t?.includeSegments){let x=new Date(i*1e3);n.push({name:"Timestamp",description:`${i} (${x.toISOString().slice(0,19)}Z)`,startByte:a+r,endByte:a+r+3,value:V(e.subarray(r,r+4))})}r+=4;let f=V(e.subarray(r,r+64));t?.includeSegments&&n.push({name:"Signature",description:"Ed25519 signature",startByte:a+r,endByte:a+r+63,value:f}),r+=64;let h=e[r];if(t?.includeSegments){let x=h.toString(2).padStart(8,"0"),u=this.parseDeviceRole(h),g=` | Bits 0-3 (Role): ${oe(u)} | Bit 4 (Location): ${h&16?"Yes":"No"} | Bit 7 (Name): ${h&128?"Yes":"No"}`;n.push({name:"App Flags",description:`Binary: ${x}${g}`,startByte:a+r,endByte:a+r,value:h.toString(16).padStart(2,"0").toUpperCase()})}r+=1;let o={type:4,version:0,isValid:!0,publicKey:c,timestamp:i,signature:f,appData:{flags:h,deviceRole:this.parseDeviceRole(h),hasLocation:!!(h&16),hasName:!!(h&128)}},d=r;if(h&16&&e.length>=d+8){let x=this.readInt32LE(e,d)/1e6,u=this.readInt32LE(e,d+4)/1e6;o.appData.location={latitude:Math.round(x*1e6)/1e6,longitude:Math.round(u*1e6)/1e6},t?.includeSegments&&(n.push({name:"Latitude",description:`${x}\xB0 (${x})`,startByte:a+d,endByte:a+d+3,value:V(e.subarray(d,d+4))}),n.push({name:"Longitude",description:`${u}\xB0 (${u})`,startByte:a+d+4,endByte:a+d+7,value:V(e.subarray(d+4,d+8))})),d+=8}if(h&32&&(d+=2),h&64&&(d+=2),h&128&&e.length>d){let x=e.subarray(d),u=new TextDecoder("utf-8").decode(x).replace(/\0.*$/,"");o.appData.name=this.sanitizeControlCharacters(u)||u,t?.includeSegments&&n.push({name:"Node Name",description:`Node name: "${o.appData.name}"`,startByte:a+d,endByte:a+e.length-1,value:V(x)})}return t?.includeSegments&&(o.segments=n),o}catch(n){return{type:4,version:0,isValid:!1,errors:[n instanceof Error?n.message:"Failed to decode advertisement payload"],publicKey:"",timestamp:0,signature:"",appData:{flags:0,deviceRole:1,hasLocation:!1,hasName:!1}}}}static async decodeWithVerification(e,t){let n=this.decode(e,t);if(!n||!n.isValid)return n;try{let r=e.subarray(100),c=V(r),i=await yt.verifyAdvertisementSignature(n.publicKey,n.signature,n.timestamp,c);n.signatureValid=i,i||(n.signatureError="Ed25519 signature verification failed",n.isValid=!1,n.errors||(n.errors=[]),n.errors.push("Invalid Ed25519 signature"))}catch(a){n.signatureValid=!1,n.signatureError=a instanceof Error?a.message:"Signature verification error",n.isValid=!1,n.errors||(n.errors=[]),n.errors.push("Signature verification failed: "+(a instanceof Error?a.message:"Unknown error"))}return n}static parseDeviceRole(e){switch(e&15){case 1:return 1;case 2:return 2;case 3:return 3;case 4:return 4;default:return 1}}static readUint32LE(e,t){return e[t]|e[t+1]<<8|e[t+2]<<16|e[t+3]<<24}static readInt32LE(e,t){let n=this.readUint32LE(e,t);return n>2147483647?n-4294967296:n}static sanitizeControlCharacters(e){return e&&e.trim().replace(/[\x00-\x1F\x7F]/g,"")||null}};var gt=class{static decode(e,t,n){try{if(e.length<9){let g={type:9,version:0,isValid:!1,errors:["Trace payload too short (need at least tag(4) + auth(4) + flags(1))"],traceTag:"00000000",authCode:0,flags:0,pathHashes:[]};return n?.includeSegments&&(g.segments=[{name:"Invalid Trace Data",description:"Trace payload too short (minimum 9 bytes required)",startByte:n.segmentOffset||0,endByte:(n.segmentOffset||0)+e.length-1,value:V(e)}]),g}let a=0,r=[],c=n?.segmentOffset||0,i=this.readUint32LE(e,a),f=G0(i,8);n?.includeSegments&&r.push({name:"Trace Tag",description:`Unique identifier for this trace: 0x${i.toString(16).padStart(8,"0")}`,startByte:c+a,endByte:c+a+3,value:V(e.slice(a,a+4))}),a+=4;let h=this.readUint32LE(e,a);n?.includeSegments&&r.push({name:"Auth Code",description:`Authentication/verification code: ${h}`,startByte:c+a,endByte:c+a+3,value:V(e.slice(a,a+4))}),a+=4;let o=e[a];n?.includeSegments&&r.push({name:"Flags",description:`Application-defined control flags: 0x${o.toString(16).padStart(2,"0")} (${o.toString(2).padStart(8,"0")}b)`,startByte:c+a,endByte:c+a,value:o.toString(16).padStart(2,"0").toUpperCase()}),a+=1;let d=[],x=a;for(;a0){let g=d.join(" ");r.push({name:"Path Hashes",description:`Node hashes in trace path: ${g}`,startByte:c+x,endByte:c+e.length-1,value:V(e.slice(x))})}let u;t&&t.length>0&&(u=t.map(g=>{let m=parseInt(g,16);return(m>127?m-256:m)/4}));let p={type:9,version:0,isValid:!0,traceTag:f,authCode:h,flags:o,pathHashes:d,snrValues:u};return n?.includeSegments&&(p.segments=r),p}catch(a){return{type:9,version:0,isValid:!1,errors:[a instanceof Error?a.message:"Failed to decode trace payload"],traceTag:"00000000",authCode:0,flags:0,pathHashes:[]}}}static readUint32LE(e,t){return e[t]|e[t+1]<<8|e[t+2]<<16|e[t+3]<<24}};var mt=class{static decode(e,t){try{if(e.length<3){let o={type:5,version:0,isValid:!1,errors:["GroupText payload too short (need at least channel_hash(1) + MAC(2))"],channelHash:"",cipherMac:"",ciphertext:"",ciphertextLength:0};return t?.includeSegments&&(o.segments=[{name:"Invalid GroupText Data",description:"GroupText payload too short (minimum 3 bytes required)",startByte:t.segmentOffset||0,endByte:(t.segmentOffset||0)+e.length-1,value:V(e)}]),o}let n=[],a=t?.segmentOffset||0,r=0,c=n0(e[r]);t?.includeSegments&&n.push({name:"Channel Hash",description:"First byte of SHA256 of channel's shared key",startByte:a+r,endByte:a+r,value:c}),r+=1;let i=V(e.subarray(r,r+2));t?.includeSegments&&n.push({name:"Cipher MAC",description:"MAC for encrypted data",startByte:a+r,endByte:a+r+1,value:i}),r+=2;let f=V(e.subarray(r));t?.includeSegments&&e.length>r&&n.push({name:"Ciphertext",description:"Encrypted message content (timestamp + flags + message)",startByte:a+r,endByte:a+e.length-1,value:f});let h={type:5,version:0,isValid:!0,channelHash:c,cipherMac:i,ciphertext:f,ciphertextLength:e.length-3};if(t?.keyStore&&t.keyStore.hasChannelKey(c)){let o=t.keyStore.getChannelKeys(c);for(let d of o){let x=K0.decryptGroupTextMessage(f,i,d);if(x.success&&x.data){h.decrypted={timestamp:x.data.timestamp,flags:x.data.flags,sender:x.data.sender,message:x.data.message};break}}}return t?.includeSegments&&(h.segments=n),h}catch(n){return{type:5,version:0,isValid:!1,errors:[n instanceof Error?n.message:"Failed to decode GroupText payload"],channelHash:"",cipherMac:"",ciphertext:"",ciphertextLength:0}}}};var Bt=class{static decode(e,t){try{if(e.length<4){let d={type:0,version:0,isValid:!1,errors:["Request payload too short (minimum 4 bytes: dest hash + source hash + MAC)"],timestamp:0,requestType:1,requestData:"",destinationHash:"",sourceHash:"",cipherMac:"",ciphertext:""};return t?.includeSegments&&(d.segments=[{name:"Invalid Request Data",description:"Request payload too short (minimum 4 bytes required: 1 for dest hash + 1 for source hash + 2 for MAC)",startByte:t.segmentOffset||0,endByte:(t.segmentOffset||0)+e.length-1,value:V(e)}]),d}let n=[],a=t?.segmentOffset||0,r=0,c=V(e.subarray(r,r+1));t?.includeSegments&&n.push({name:"Destination Hash",description:`First byte of destination node public key: 0x${c}`,startByte:a+r,endByte:a+r,value:c}),r+=1;let i=V(e.subarray(r,r+1));t?.includeSegments&&n.push({name:"Source Hash",description:`First byte of source node public key: 0x${i}`,startByte:a+r,endByte:a+r,value:i}),r+=1;let f=V(e.subarray(r,r+2));t?.includeSegments&&n.push({name:"Cipher MAC",description:"MAC for encrypted data verification (2 bytes)",startByte:a+r,endByte:a+r+1,value:f}),r+=2;let h=V(e.subarray(r));t?.includeSegments&&e.length>r&&n.push({name:"Ciphertext",description:`Encrypted message data (${e.length-r} bytes). Contains encrypted plaintext with this structure: +\u2022 Timestamp (4 bytes) - send time as unix timestamp +\u2022 Request Type (1 byte) - type of request (GetStats, GetTelemetryData, etc.) +\u2022 Request Data (remaining bytes) - additional request-specific data`,startByte:a+r,endByte:a+e.length-1,value:h});let o={type:0,version:0,isValid:!0,timestamp:0,requestType:1,requestData:"",destinationHash:c,sourceHash:i,cipherMac:f,ciphertext:h};return t?.includeSegments&&(o.segments=n),o}catch(n){return{type:0,version:0,isValid:!1,errors:[n instanceof Error?n.message:"Failed to decode request payload"],timestamp:0,requestType:1,requestData:"",destinationHash:"",sourceHash:"",cipherMac:"",ciphertext:""}}}};var Ct=class{static decode(e,t){try{if(e.length<4){let d={type:1,version:0,isValid:!1,errors:["Response payload too short (minimum 4 bytes: dest + source + MAC)"],destinationHash:"",sourceHash:"",cipherMac:"",ciphertext:"",ciphertextLength:0};return t?.includeSegments&&(d.segments=[{name:"Invalid Response Data",description:"Response payload too short (minimum 4 bytes required)",startByte:t.segmentOffset||0,endByte:(t.segmentOffset||0)+e.length-1,value:V(e)}]),d}let n=[],a=t?.segmentOffset||0,r=0,c=n0(e[r]);t?.includeSegments&&n.push({name:"Destination Hash",description:"First byte of destination node public key",startByte:a+r,endByte:a+r,value:c}),r+=1;let i=n0(e[r]);t?.includeSegments&&n.push({name:"Source Hash",description:"First byte of source node public key",startByte:a+r,endByte:a+r,value:i}),r+=1;let f=V(e.subarray(r,r+2));t?.includeSegments&&n.push({name:"Cipher MAC",description:"MAC for encrypted data in next field",startByte:a+r,endByte:a+r+1,value:f}),r+=2;let h=V(e.subarray(r));t?.includeSegments&&e.length>r&&n.push({name:"Ciphertext",description:"Encrypted response data (tag + content)",startByte:a+r,endByte:a+e.length-1,value:h});let o={type:1,version:0,isValid:!0,destinationHash:c,sourceHash:i,cipherMac:f,ciphertext:h,ciphertextLength:e.length-4};return t?.includeSegments&&(o.segments=n),o}catch(n){return{type:1,version:0,isValid:!1,errors:[n instanceof Error?n.message:"Failed to decode response payload"],destinationHash:"",sourceHash:"",cipherMac:"",ciphertext:"",ciphertextLength:0}}}};var At=class{static decode(e,t){try{if(e.length<35){let d={type:7,version:0,isValid:!1,errors:["AnonRequest payload too short (minimum 35 bytes: dest + public key + MAC)"],destinationHash:"",senderPublicKey:"",cipherMac:"",ciphertext:"",ciphertextLength:0};return t?.includeSegments&&(d.segments=[{name:"Invalid AnonRequest Data",description:"AnonRequest payload too short (minimum 35 bytes required: 1 for dest hash + 32 for public key + 2 for MAC)",startByte:t.segmentOffset||0,endByte:(t.segmentOffset||0)+e.length-1,value:V(e)}]),d}let n=[],a=t?.segmentOffset||0,r=0,c=n0(e[0]);t?.includeSegments&&n.push({name:"Destination Hash",description:`First byte of destination node public key: 0x${c}`,startByte:a+r,endByte:a+r,value:c}),r+=1;let i=V(e.subarray(1,33));t?.includeSegments&&n.push({name:"Sender Public Key",description:"Ed25519 public key of the sender (32 bytes)",startByte:a+r,endByte:a+r+31,value:i}),r+=32;let f=V(e.subarray(33,35));t?.includeSegments&&n.push({name:"Cipher MAC",description:"MAC for encrypted data verification (2 bytes)",startByte:a+r,endByte:a+r+1,value:f}),r+=2;let h=V(e.subarray(35));t?.includeSegments&&e.length>35&&n.push({name:"Ciphertext",description:`Encrypted message data (${e.length-35} bytes). Contains encrypted plaintext with this structure: +\u2022 Timestamp (4 bytes) - send time as unix timestamp +\u2022 Sync Timestamp (4 bytes) - room server only, sender's "sync messages SINCE x" timestamp +\u2022 Password (remaining bytes) - password for repeater/room`,startByte:a+r,endByte:a+e.length-1,value:h});let o={type:7,version:0,isValid:!0,destinationHash:c,senderPublicKey:i,cipherMac:f,ciphertext:h,ciphertextLength:e.length-35};return t?.includeSegments&&(o.segments=n),o}catch(n){return{type:7,version:0,isValid:!1,errors:[n instanceof Error?n.message:"Failed to decode AnonRequest payload"],destinationHash:"",senderPublicKey:"",cipherMac:"",ciphertext:"",ciphertextLength:0}}}};var Et=class{static decode(e,t){try{if(e.length<4){let i={type:3,version:0,isValid:!1,errors:["Ack payload too short (minimum 4 bytes for checksum)"],checksum:""};return t?.includeSegments&&(i.segments=[{name:"Invalid Ack Data",description:"Ack payload too short (minimum 4 bytes required for checksum)",startByte:t.segmentOffset||0,endByte:(t.segmentOffset||0)+e.length-1,value:V(e)}]),i}let n=[],a=t?.segmentOffset||0,r=V(e.subarray(0,4));t?.includeSegments&&n.push({name:"Checksum",description:`CRC checksum of message timestamp, text, and sender pubkey: 0x${r}`,startByte:a,endByte:a+3,value:r}),t?.includeSegments&&e.length>4&&n.push({name:"Additional Data",description:"Extra data in Ack payload",startByte:a+4,endByte:a+e.length-1,value:V(e.subarray(4))});let c={type:3,version:0,isValid:!0,checksum:r};return t?.includeSegments&&(c.segments=n),c}catch(n){return{type:3,version:0,isValid:!1,errors:[n instanceof Error?n.message:"Failed to decode Ack payload"],checksum:""}}}};var Dt=class{static decode(e){try{if(e.length<2)return{type:8,version:0,isValid:!1,errors:["Path payload too short (minimum 2 bytes: path length + extra type)"],pathLength:0,pathHashes:[],extraType:0,extraData:""};let t=e[0];if(e.length<1+t+1)return{type:8,version:0,isValid:!1,errors:[`Path payload too short (need ${1+t+1} bytes for path length + path + extra type)`],pathLength:t,pathHashes:[],extraType:0,extraData:""};let n=[];for(let c=0;c1+t+1&&(r=V(e.subarray(1+t+1))),{type:8,version:0,isValid:!0,pathLength:t,pathHashes:n,extraType:a,extraData:r}}catch(t){return{type:8,version:0,isValid:!1,errors:[t instanceof Error?t.message:"Failed to decode Path payload"],pathLength:0,pathHashes:[],extraType:0,extraData:""}}}};var bt=class{static decode(e,t){try{if(e.length<4){let d={type:2,version:0,isValid:!1,errors:["TextMessage payload too short (minimum 4 bytes: dest + source + MAC)"],destinationHash:"",sourceHash:"",cipherMac:"",ciphertext:"",ciphertextLength:0};return t?.includeSegments&&(d.segments=[{name:"Invalid TextMessage Data",description:"TextMessage payload too short (minimum 4 bytes required)",startByte:t.segmentOffset||0,endByte:(t.segmentOffset||0)+e.length-1,value:V(e)}]),d}let n=[],a=t?.segmentOffset||0,r=0,c=n0(e[r]);t?.includeSegments&&n.push({name:"Destination Hash",description:"First byte of destination node public key",startByte:a+r,endByte:a+r,value:c}),r+=1;let i=n0(e[r]);t?.includeSegments&&n.push({name:"Source Hash",description:"First byte of source node public key",startByte:a+r,endByte:a+r,value:i}),r+=1;let f=V(e.subarray(r,r+2));t?.includeSegments&&n.push({name:"Cipher MAC",description:"MAC for encrypted data in next field",startByte:a+r,endByte:a+r+1,value:f}),r+=2;let h=V(e.subarray(r));t?.includeSegments&&e.length>r&&n.push({name:"Ciphertext",description:"Encrypted message data (timestamp + message text)",startByte:a+r,endByte:a+e.length-1,value:h});let o={type:2,version:0,isValid:!0,destinationHash:c,sourceHash:i,cipherMac:f,ciphertext:h,ciphertextLength:e.length-4};return t?.includeSegments&&(o.segments=n),o}catch(n){return{type:2,version:0,isValid:!1,errors:[n instanceof Error?n.message:"Failed to decode TextMessage payload"],destinationHash:"",sourceHash:"",cipherMac:"",ciphertext:"",ciphertextLength:0}}}};var Ft=class{static decode(e,t){try{if(e.length<1)return this.createErrorPayload("Control payload too short (minimum 1 byte required)",e,t);let a=e[0]&240;switch(a){case 128:return this.decodeDiscoverReq(e,t);case 144:return this.decodeDiscoverResp(e,t);default:return this.createErrorPayload(`Unknown control sub-type: 0x${a.toString(16).padStart(2,"0")}`,e,t)}}catch(n){return this.createErrorPayload(n instanceof Error?n.message:"Failed to decode control payload",e,t)}}static decodeDiscoverReq(e,t){let n=[],a=t?.segmentOffset??0;if(e.length<6){let u={type:11,version:0,isValid:!1,errors:["DISCOVER_REQ payload too short (minimum 6 bytes required)"],subType:128,rawFlags:e[0],prefixOnly:!1,typeFilter:0,typeFilterNames:[],tag:0,since:0};return t?.includeSegments&&(u.segments=[{name:"Invalid DISCOVER_REQ Data",description:"DISCOVER_REQ payload too short (minimum 6 bytes required)",startByte:a,endByte:a+e.length-1,value:V(e)}]),u}let r=0,c=e[r],i=(c&1)!==0;t?.includeSegments&&n.push({name:"Flags",description:`Sub-type: DISCOVER_REQ (0x8) | Prefix Only: ${i}`,startByte:a+r,endByte:a+r,value:c.toString(16).padStart(2,"0").toUpperCase()}),r+=1;let f=e[r],h=this.parseTypeFilter(f);t?.includeSegments&&n.push({name:"Type Filter",description:`Filter mask: 0b${f.toString(2).padStart(8,"0")} | Types: ${h.length>0?h.join(", "):"None"}`,startByte:a+r,endByte:a+r,value:f.toString(16).padStart(2,"0").toUpperCase()}),r+=1;let o=this.readUint32LE(e,r);t?.includeSegments&&n.push({name:"Tag",description:`Random tag for response matching: 0x${o.toString(16).padStart(8,"0")}`,startByte:a+r,endByte:a+r+3,value:V(e.slice(r,r+4))}),r+=4;let d=0;if(e.length>=r+4&&(d=this.readUint32LE(e,r),t?.includeSegments)){let u=d>0?new Date(d*1e3).toISOString().slice(0,19)+"Z":"N/A";n.push({name:"Since",description:`Filter timestamp: ${d} (${u})`,startByte:a+r,endByte:a+r+3,value:V(e.slice(r,r+4))})}let x={type:11,version:0,isValid:!0,subType:128,rawFlags:c,prefixOnly:i,typeFilter:f,typeFilterNames:h,tag:o,since:d};return t?.includeSegments&&(x.segments=n),x}static decodeDiscoverResp(e,t){let n=[],a=t?.segmentOffset??0;if(e.length<14){let v={type:11,version:0,isValid:!1,errors:["DISCOVER_RESP payload too short (minimum 14 bytes required)"],subType:144,rawFlags:e.length>0?e[0]:0,nodeType:0,nodeTypeName:"Unknown",snr:0,tag:0,publicKey:"",publicKeyLength:0};return t?.includeSegments&&(v.segments=[{name:"Invalid DISCOVER_RESP Data",description:"DISCOVER_RESP payload too short (minimum 14 bytes required)",startByte:a,endByte:a+e.length-1,value:V(e)}]),v}let r=0,c=e[r],i=c&15,f=oe(i);t?.includeSegments&&n.push({name:"Flags",description:`Sub-type: DISCOVER_RESP (0x9) | Node Type: ${f}`,startByte:a+r,endByte:a+r,value:c.toString(16).padStart(2,"0").toUpperCase()}),r+=1;let h=e[r],o=h>127?h-256:h,d=o/4;t?.includeSegments&&n.push({name:"SNR",description:`Inbound SNR: ${d.toFixed(2)} dB (raw: ${h}, signed: ${o})`,startByte:a+r,endByte:a+r,value:h.toString(16).padStart(2,"0").toUpperCase()}),r+=1;let x=this.readUint32LE(e,r);t?.includeSegments&&n.push({name:"Tag",description:`Reflected tag from request: 0x${x.toString(16).padStart(8,"0")}`,startByte:a+r,endByte:a+r+3,value:V(e.slice(r,r+4))}),r+=4;let p=e.length-r,g=e.slice(r,r+p),m=V(g);if(t?.includeSegments){let v=p===32?"Full Public Key":"Public Key Prefix";n.push({name:v,description:`${v} (${p} bytes)`,startByte:a+r,endByte:a+r+p-1,value:m})}let l={type:11,version:0,isValid:!0,subType:144,rawFlags:c,nodeType:i,nodeTypeName:f,snr:d,tag:x,publicKey:m,publicKeyLength:p};return t?.includeSegments&&(l.segments=n),l}static parseTypeFilter(e){let t=[];return e&2&&t.push("Chat"),e&4&&t.push("Repeater"),e&8&&t.push("Room"),e&16&&t.push("Sensor"),t}static createErrorPayload(e,t,n){let a={type:11,version:0,isValid:!1,errors:[e],subType:128,rawFlags:t.length>0?t[0]:0,prefixOnly:!1,typeFilter:0,typeFilterNames:[],tag:0,since:0};return n?.includeSegments&&(a.segments=[{name:"Invalid Control Data",description:e,startByte:n.segmentOffset??0,endByte:(n.segmentOffset??0)+t.length-1,value:V(t)}]),a}static readUint32LE(e,t){return(e[t]|e[t+1]<<8|e[t+2]<<16|e[t+3]<<24)>>>0}};var j0=class{static decode(e,t){return this.parseInternal(e,!1,t).packet}static async decodeWithVerification(e,t){return(await this.parseInternalAsync(e,!1,t)).packet}static analyzeStructure(e,t){return this.parseInternal(e,!0,t).structure}static async analyzeStructureWithVerification(e,t){return(await this.parseInternalAsync(e,!0,t)).structure}static parseInternal(e,t,n){let a=Z(e),r=[];if(a.length<2){let c={messageHash:"",routeType:1,payloadType:15,payloadVersion:0,pathLength:0,path:null,payload:{raw:"",decoded:null},totalBytes:a.length,isValid:!1,errors:["Packet too short (minimum 2 bytes required)"]},i={segments:[],totalBytes:a.length,rawHex:e.toUpperCase(),messageHash:"",payload:{segments:[],hex:"",startByte:0,type:"Unknown"}};return{packet:c,structure:i}}try{let c=0,i=a[0],f=i&3,h=i>>2&15,o=i>>6&3;t&&r.push({name:"Header",description:"Header byte breakdown",startByte:0,endByte:0,value:`0x${i.toString(16).padStart(2,"0")}`,headerBreakdown:{fullBinary:i.toString(2).padStart(8,"0"),fields:[{bits:"0-1",field:"Route Type",value:Yt(f),binary:(i&3).toString(2).padStart(2,"0")},{bits:"2-5",field:"Payload Type",value:L0(h),binary:(i>>2&15).toString(2).padStart(4,"0")},{bits:"6-7",field:"Version",value:o.toString(),binary:(i>>6&3).toString(2).padStart(2,"0")}]}}),c=1;let d;if(f===0||f===3){if(a.length0?Array.from(u).map(n0):null;if(t&&x>0)if(h===9){let y=[];for(let w=0;w127?S-256:S)/4;y.push(`${q.toFixed(2)}dB (0x${S.toString(16).padStart(2,"0")})`)}r.push({name:"Path SNR Data",description:`SNR values collected during trace: ${y.join(", ")}`,startByte:c,endByte:c+x-1,value:V(a.slice(c,c+x))})}else{let y="Routing path information";f===2||f===3?y="Routing instructions (bytes are stripped at each hop as packet travels to destination)":(f===1||f===0)&&(y="Historical route taken (bytes are added as packet floods through network)"),r.push({name:"Path Data",description:y,startByte:c,endByte:c+x-1,value:V(a.slice(c,c+x))})}c+=x;let g=a.subarray(c),m=V(g);t&&a.length>c&&r.push({name:"Payload",description:`${L0(h)} payload data`,startByte:c,endByte:a.length-1,value:V(a.slice(c))});let l=null,v=[];if(h===4){let y=xe.decode(g,{includeSegments:t,segmentOffset:0});l=y,y?.segments&&(v.push(...y.segments),delete y.segments)}else if(h===9){let y=gt.decode(g,p,{includeSegments:t,segmentOffset:0});l=y,y?.segments&&(v.push(...y.segments),delete y.segments)}else if(h===5){let y=mt.decode(g,{...n,includeSegments:t,segmentOffset:0});l=y,y?.segments&&(v.push(...y.segments),delete y.segments)}else if(h===0){let y=Bt.decode(g,{includeSegments:t,segmentOffset:0});l=y,y?.segments&&(v.push(...y.segments),delete y.segments)}else if(h===1){let y=Ct.decode(g,{includeSegments:t,segmentOffset:0});l=y,y?.segments&&(v.push(...y.segments),delete y.segments)}else if(h===7){let y=At.decode(g,{includeSegments:t,segmentOffset:0});l=y,y?.segments&&(v.push(...y.segments),delete y.segments)}else if(h===3){let y=Et.decode(g,{includeSegments:t,segmentOffset:0});l=y,y?.segments&&(v.push(...y.segments),delete y.segments)}else if(h===8)l=Dt.decode(g);else if(h===2){let y=bt.decode(g,{includeSegments:t,segmentOffset:0});l=y,y?.segments&&(v.push(...y.segments),delete y.segments)}else if(h===11){let y=Ft.decode(g,{includeSegments:t,segmentOffset:0});l=y,y?.segments&&(v.push(...y.segments),delete y.segments)}t&&v.length===0&&a.length>c&&v.push({name:`${L0(h)} Payload`,description:`Raw ${L0(h)} payload data (${g.length} bytes)`,startByte:0,endByte:g.length-1,value:V(g)});let C=this.calculateMessageHash(a,f,h,o),B={messageHash:C,routeType:f,payloadType:h,payloadVersion:o,transportCodes:d,pathLength:x,path:p,payload:{raw:m,decoded:l},totalBytes:a.length,isValid:!0},A={segments:r,totalBytes:a.length,rawHex:e.toUpperCase(),messageHash:C,payload:{segments:v,hex:m,startByte:c,type:L0(h)}};return{packet:B,structure:A}}catch(c){let i={messageHash:"",routeType:1,payloadType:15,payloadVersion:0,pathLength:0,path:null,payload:{raw:"",decoded:null},totalBytes:a.length,isValid:!1,errors:[c instanceof Error?c.message:"Unknown decoding error"]},f={segments:[],totalBytes:a.length,rawHex:e.toUpperCase(),messageHash:"",payload:{segments:[],hex:"",startByte:0,type:"Unknown"}};return{packet:i,structure:f}}}static async parseInternalAsync(e,t,n){let a=this.parseInternal(e,t,n);if(a.packet.payloadType===4&&a.packet.payload.decoded)try{let r=a.packet.payload.decoded,c=await xe.decodeWithVerification(Z(a.packet.payload.raw),{includeSegments:t,segmentOffset:0});c&&(a.packet.payload.decoded=c,c.isValid||(a.packet.isValid=!1,a.packet.errors=c.errors||["Invalid advertisement signature"]),t&&c.segments&&(a.structure.payload.segments=c.segments,delete c.segments))}catch(r){console.error("Signature verification failed:",r)}return a}static validate(e){let t=Z(e),n=[];if(t.length<2)return n.push("Packet too short (minimum 2 bytes required)"),{isValid:!1,errors:n};try{let a=1,c=t[0]&3;if((c===0||c===3)&&(t.length=t.length&&n.push("No payload data found")}catch(a){n.push(a instanceof Error?a.message:"Validation error")}return{isValid:n.length===0,errors:n.length>0?n:void 0}}static calculateMessageHash(e,t,n,a){if(n===9&&e.length>=13){let o=1;if((t===0||t===3)&&(o+=4),e.length>o){let d=e[o];o+=1+d}if(e.length>=o+4){let d=e[o]|e[o+1]<<8|e[o+2]<<16|e[o+3]<<24;return G0(d,8)}}let r=n<<2|a<<6,c=1;if((t===0||t===3)&&(c+=4),e.length>c){let o=e[c];c+=1+o}let i=e.slice(c),f=[r,...Array.from(i)],h=0;for(let o=0;o>>24&255,n[a*4+1]=r>>>16&255,n[a*4+2]=r>>>8&255,n[a*4+3]=r&255}return n}E0.sha512Sync=zn;E0.sha512Async=async s=>zn(s);var Vn=class{static async verifyAdvertisementSignature(e,t,n,a){try{let r=Z(e),c=Z(t),i=Z(a),f=this.constructAdvertSignedMessage(e,n,i);return await ne(c,f,r)}catch(r){return console.error("Ed25519 signature verification failed:",r),!1}}static constructAdvertSignedMessage(e,t,n){let a=Z(e),r=new Uint8Array(4);r[0]=t&255,r[1]=t>>8&255,r[2]=t>>16&255,r[3]=t>>24&255;let c=new Uint8Array(36+n.length);return c.set(a,0),c.set(r,32),c.set(n,36),c}static getSignedMessageHex(e,t,n){let a=Z(n),r=this.constructAdvertSignedMessage(e,t,a);return V(r)}};function Ha(s,e){return j0.decode(s,e)}function Ra(s,e){return j0.analyzeStructure(s,e)}async function Ta(s,e){return j0.decodeWithVerification(s,e)}function qa(){return typeof globalThis>"u"||typeof globalThis.window>"u"?!0:globalThis.isSecureContext??!1}function Ua(){return typeof globalThis<"u"&&globalThis.crypto!==void 0&&globalThis.crypto.subtle!==void 0}export{Zt as AdvertFlags,K0 as ChannelCrypto,ht as ControlSubType,ae as DeviceRole,Vn as Ed25519SignatureVerifier,j0 as MeshCoreDecoder,ie as MeshCoreKeyStore,j0 as MeshCorePacketDecoder,c0 as PayloadType,f0 as PayloadVersion,vt as RequestType,ut as RouteType,Ra as analyzePacket,n0 as byteToHex,V as bytesToHex,Ha as decodePacket,Ta as decodePacketWithVerification,Gt as ed25519,ds as getControlSubTypeName,oe as getDeviceRoleName,L0 as getPayloadTypeName,cs as getPayloadVersionName,fs as getRequestTypeName,Yt as getRouteTypeName,Ua as hasWebCrypto,Z as hexToBytes,qa as isSecureContext,G0 as numberToHex}; +/*! Bundled license information: + +crypto-js/ripemd160.js: + (** @preserve + (c) 2012 by Cédric Mesnil. All rights reserved. + + Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met: + + - Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer. + - Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution. + + THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + *) + +crypto-js/mode-ctr-gladman.js: + (** @preserve + * Counter block mode compatible with Dr Brian Gladman fileenc.c + * derived from CryptoJS.mode.CTR + * Jan Hruby jhruby.web@gmail.com + *) + +@noble/ed25519/index.js: + (*! noble-ed25519 - MIT License (c) 2019 Paul Miller (paulmillr.com) *) +*/ diff --git a/modules/web_viewer/static/js/meshcore-browser.mjs b/modules/web_viewer/static/js/meshcore-browser.mjs new file mode 100644 index 0000000..854cd46 --- /dev/null +++ b/modules/web_viewer/static/js/meshcore-browser.mjs @@ -0,0 +1,9968 @@ +var __create = Object.create; +var __defProp = Object.defineProperty; +var __getOwnPropDesc = Object.getOwnPropertyDescriptor; +var __getOwnPropNames = Object.getOwnPropertyNames; +var __getProtoOf = Object.getPrototypeOf; +var __hasOwnProp = Object.prototype.hasOwnProperty; +var __require = /* @__PURE__ */ ((x) => typeof require !== "undefined" ? require : typeof Proxy !== "undefined" ? new Proxy(x, { + get: (a, b) => (typeof require !== "undefined" ? require : a)[b] +}) : x)(function(x) { + if (typeof require !== "undefined") return require.apply(this, arguments); + throw Error('Dynamic require of "' + x + '" is not supported'); +}); +var __commonJS = (cb, mod) => function __require2() { + return mod || (0, cb[__getOwnPropNames(cb)[0]])((mod = { exports: {} }).exports, mod), mod.exports; +}; +var __export = (target, all) => { + for (var name in all) + __defProp(target, name, { get: all[name], enumerable: true }); +}; +var __copyProps = (to, from, except, desc) => { + if (from && typeof from === "object" || typeof from === "function") { + for (let key of __getOwnPropNames(from)) + if (!__hasOwnProp.call(to, key) && key !== except) + __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable }); + } + return to; +}; +var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps( + // If the importer is in node compatibility mode or this is not an ESM + // file that has been converted to a CommonJS file using a Babel- + // compatible transform (i.e. "__esModule" has not been set), then set + // "default" to the CommonJS "module.exports" for node compatibility. + isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target, + mod +)); + +// (disabled):crypto +var require_crypto = __commonJS({ + "(disabled):crypto"() { + } +}); + +// node_modules/crypto-js/core.js +var require_core = __commonJS({ + "node_modules/crypto-js/core.js"(exports, module) { + (function(root, factory) { + if (typeof exports === "object") { + module.exports = exports = factory(); + } else if (typeof define === "function" && define.amd) { + define([], factory); + } else { + root.CryptoJS = factory(); + } + })(exports, function() { + var CryptoJS2 = CryptoJS2 || (function(Math2, undefined2) { + var crypto; + if (typeof window !== "undefined" && window.crypto) { + crypto = window.crypto; + } + if (typeof self !== "undefined" && self.crypto) { + crypto = self.crypto; + } + if (typeof globalThis !== "undefined" && globalThis.crypto) { + crypto = globalThis.crypto; + } + if (!crypto && typeof window !== "undefined" && window.msCrypto) { + crypto = window.msCrypto; + } + if (!crypto && typeof global !== "undefined" && global.crypto) { + crypto = global.crypto; + } + if (!crypto && typeof __require === "function") { + try { + crypto = require_crypto(); + } catch (err2) { + } + } + var cryptoSecureRandomInt = function() { + if (crypto) { + if (typeof crypto.getRandomValues === "function") { + try { + return crypto.getRandomValues(new Uint32Array(1))[0]; + } catch (err2) { + } + } + if (typeof crypto.randomBytes === "function") { + try { + return crypto.randomBytes(4).readInt32LE(); + } catch (err2) { + } + } + } + throw new Error("Native crypto module could not be used to get secure random number."); + }; + var create = Object.create || /* @__PURE__ */ (function() { + function F() { + } + return function(obj) { + var subtype; + F.prototype = obj; + subtype = new F(); + F.prototype = null; + return subtype; + }; + })(); + var C2 = {}; + var C_lib = C2.lib = {}; + var Base = C_lib.Base = /* @__PURE__ */ (function() { + return { + /** + * Creates a new object that inherits from this object. + * + * @param {Object} overrides Properties to copy into the new object. + * + * @return {Object} The new object. + * + * @static + * + * @example + * + * var MyType = CryptoJS.lib.Base.extend({ + * field: 'value', + * + * method: function () { + * } + * }); + */ + extend: function(overrides) { + var subtype = create(this); + if (overrides) { + subtype.mixIn(overrides); + } + if (!subtype.hasOwnProperty("init") || this.init === subtype.init) { + subtype.init = function() { + subtype.$super.init.apply(this, arguments); + }; + } + subtype.init.prototype = subtype; + subtype.$super = this; + return subtype; + }, + /** + * Extends this object and runs the init method. + * Arguments to create() will be passed to init(). + * + * @return {Object} The new object. + * + * @static + * + * @example + * + * var instance = MyType.create(); + */ + create: function() { + var instance = this.extend(); + instance.init.apply(instance, arguments); + return instance; + }, + /** + * Initializes a newly created object. + * Override this method to add some logic when your objects are created. + * + * @example + * + * var MyType = CryptoJS.lib.Base.extend({ + * init: function () { + * // ... + * } + * }); + */ + init: function() { + }, + /** + * Copies properties into this object. + * + * @param {Object} properties The properties to mix in. + * + * @example + * + * MyType.mixIn({ + * field: 'value' + * }); + */ + mixIn: function(properties) { + for (var propertyName in properties) { + if (properties.hasOwnProperty(propertyName)) { + this[propertyName] = properties[propertyName]; + } + } + if (properties.hasOwnProperty("toString")) { + this.toString = properties.toString; + } + }, + /** + * Creates a copy of this object. + * + * @return {Object} The clone. + * + * @example + * + * var clone = instance.clone(); + */ + clone: function() { + return this.init.prototype.extend(this); + } + }; + })(); + var WordArray = C_lib.WordArray = Base.extend({ + /** + * Initializes a newly created word array. + * + * @param {Array} words (Optional) An array of 32-bit words. + * @param {number} sigBytes (Optional) The number of significant bytes in the words. + * + * @example + * + * var wordArray = CryptoJS.lib.WordArray.create(); + * var wordArray = CryptoJS.lib.WordArray.create([0x00010203, 0x04050607]); + * var wordArray = CryptoJS.lib.WordArray.create([0x00010203, 0x04050607], 6); + */ + init: function(words, sigBytes) { + words = this.words = words || []; + if (sigBytes != undefined2) { + this.sigBytes = sigBytes; + } else { + this.sigBytes = words.length * 4; + } + }, + /** + * Converts this word array to a string. + * + * @param {Encoder} encoder (Optional) The encoding strategy to use. Default: CryptoJS.enc.Hex + * + * @return {string} The stringified word array. + * + * @example + * + * var string = wordArray + ''; + * var string = wordArray.toString(); + * var string = wordArray.toString(CryptoJS.enc.Utf8); + */ + toString: function(encoder) { + return (encoder || Hex).stringify(this); + }, + /** + * Concatenates a word array to this word array. + * + * @param {WordArray} wordArray The word array to append. + * + * @return {WordArray} This word array. + * + * @example + * + * wordArray1.concat(wordArray2); + */ + concat: function(wordArray) { + var thisWords = this.words; + var thatWords = wordArray.words; + var thisSigBytes = this.sigBytes; + var thatSigBytes = wordArray.sigBytes; + this.clamp(); + if (thisSigBytes % 4) { + for (var i = 0; i < thatSigBytes; i++) { + var thatByte = thatWords[i >>> 2] >>> 24 - i % 4 * 8 & 255; + thisWords[thisSigBytes + i >>> 2] |= thatByte << 24 - (thisSigBytes + i) % 4 * 8; + } + } else { + for (var j = 0; j < thatSigBytes; j += 4) { + thisWords[thisSigBytes + j >>> 2] = thatWords[j >>> 2]; + } + } + this.sigBytes += thatSigBytes; + return this; + }, + /** + * Removes insignificant bits. + * + * @example + * + * wordArray.clamp(); + */ + clamp: function() { + var words = this.words; + var sigBytes = this.sigBytes; + words[sigBytes >>> 2] &= 4294967295 << 32 - sigBytes % 4 * 8; + words.length = Math2.ceil(sigBytes / 4); + }, + /** + * Creates a copy of this word array. + * + * @return {WordArray} The clone. + * + * @example + * + * var clone = wordArray.clone(); + */ + clone: function() { + var clone = Base.clone.call(this); + clone.words = this.words.slice(0); + return clone; + }, + /** + * Creates a word array filled with random bytes. + * + * @param {number} nBytes The number of random bytes to generate. + * + * @return {WordArray} The random word array. + * + * @static + * + * @example + * + * var wordArray = CryptoJS.lib.WordArray.random(16); + */ + random: function(nBytes) { + var words = []; + for (var i = 0; i < nBytes; i += 4) { + words.push(cryptoSecureRandomInt()); + } + return new WordArray.init(words, nBytes); + } + }); + var C_enc = C2.enc = {}; + var Hex = C_enc.Hex = { + /** + * Converts a word array to a hex string. + * + * @param {WordArray} wordArray The word array. + * + * @return {string} The hex string. + * + * @static + * + * @example + * + * var hexString = CryptoJS.enc.Hex.stringify(wordArray); + */ + stringify: function(wordArray) { + var words = wordArray.words; + var sigBytes = wordArray.sigBytes; + var hexChars = []; + for (var i = 0; i < sigBytes; i++) { + var bite = words[i >>> 2] >>> 24 - i % 4 * 8 & 255; + hexChars.push((bite >>> 4).toString(16)); + hexChars.push((bite & 15).toString(16)); + } + return hexChars.join(""); + }, + /** + * Converts a hex string to a word array. + * + * @param {string} hexStr The hex string. + * + * @return {WordArray} The word array. + * + * @static + * + * @example + * + * var wordArray = CryptoJS.enc.Hex.parse(hexString); + */ + parse: function(hexStr) { + var hexStrLength = hexStr.length; + var words = []; + for (var i = 0; i < hexStrLength; i += 2) { + words[i >>> 3] |= parseInt(hexStr.substr(i, 2), 16) << 24 - i % 8 * 4; + } + return new WordArray.init(words, hexStrLength / 2); + } + }; + var Latin1 = C_enc.Latin1 = { + /** + * Converts a word array to a Latin1 string. + * + * @param {WordArray} wordArray The word array. + * + * @return {string} The Latin1 string. + * + * @static + * + * @example + * + * var latin1String = CryptoJS.enc.Latin1.stringify(wordArray); + */ + stringify: function(wordArray) { + var words = wordArray.words; + var sigBytes = wordArray.sigBytes; + var latin1Chars = []; + for (var i = 0; i < sigBytes; i++) { + var bite = words[i >>> 2] >>> 24 - i % 4 * 8 & 255; + latin1Chars.push(String.fromCharCode(bite)); + } + return latin1Chars.join(""); + }, + /** + * Converts a Latin1 string to a word array. + * + * @param {string} latin1Str The Latin1 string. + * + * @return {WordArray} The word array. + * + * @static + * + * @example + * + * var wordArray = CryptoJS.enc.Latin1.parse(latin1String); + */ + parse: function(latin1Str) { + var latin1StrLength = latin1Str.length; + var words = []; + for (var i = 0; i < latin1StrLength; i++) { + words[i >>> 2] |= (latin1Str.charCodeAt(i) & 255) << 24 - i % 4 * 8; + } + return new WordArray.init(words, latin1StrLength); + } + }; + var Utf8 = C_enc.Utf8 = { + /** + * Converts a word array to a UTF-8 string. + * + * @param {WordArray} wordArray The word array. + * + * @return {string} The UTF-8 string. + * + * @static + * + * @example + * + * var utf8String = CryptoJS.enc.Utf8.stringify(wordArray); + */ + stringify: function(wordArray) { + try { + return decodeURIComponent(escape(Latin1.stringify(wordArray))); + } catch (e) { + throw new Error("Malformed UTF-8 data"); + } + }, + /** + * Converts a UTF-8 string to a word array. + * + * @param {string} utf8Str The UTF-8 string. + * + * @return {WordArray} The word array. + * + * @static + * + * @example + * + * var wordArray = CryptoJS.enc.Utf8.parse(utf8String); + */ + parse: function(utf8Str) { + return Latin1.parse(unescape(encodeURIComponent(utf8Str))); + } + }; + var BufferedBlockAlgorithm = C_lib.BufferedBlockAlgorithm = Base.extend({ + /** + * Resets this block algorithm's data buffer to its initial state. + * + * @example + * + * bufferedBlockAlgorithm.reset(); + */ + reset: function() { + this._data = new WordArray.init(); + this._nDataBytes = 0; + }, + /** + * Adds new data to this block algorithm's buffer. + * + * @param {WordArray|string} data The data to append. Strings are converted to a WordArray using UTF-8. + * + * @example + * + * bufferedBlockAlgorithm._append('data'); + * bufferedBlockAlgorithm._append(wordArray); + */ + _append: function(data) { + if (typeof data == "string") { + data = Utf8.parse(data); + } + this._data.concat(data); + this._nDataBytes += data.sigBytes; + }, + /** + * Processes available data blocks. + * + * This method invokes _doProcessBlock(offset), which must be implemented by a concrete subtype. + * + * @param {boolean} doFlush Whether all blocks and partial blocks should be processed. + * + * @return {WordArray} The processed data. + * + * @example + * + * var processedData = bufferedBlockAlgorithm._process(); + * var processedData = bufferedBlockAlgorithm._process(!!'flush'); + */ + _process: function(doFlush) { + var processedWords; + var data = this._data; + var dataWords = data.words; + var dataSigBytes = data.sigBytes; + var blockSize = this.blockSize; + var blockSizeBytes = blockSize * 4; + var nBlocksReady = dataSigBytes / blockSizeBytes; + if (doFlush) { + nBlocksReady = Math2.ceil(nBlocksReady); + } else { + nBlocksReady = Math2.max((nBlocksReady | 0) - this._minBufferSize, 0); + } + var nWordsReady = nBlocksReady * blockSize; + var nBytesReady = Math2.min(nWordsReady * 4, dataSigBytes); + if (nWordsReady) { + for (var offset = 0; offset < nWordsReady; offset += blockSize) { + this._doProcessBlock(dataWords, offset); + } + processedWords = dataWords.splice(0, nWordsReady); + data.sigBytes -= nBytesReady; + } + return new WordArray.init(processedWords, nBytesReady); + }, + /** + * Creates a copy of this object. + * + * @return {Object} The clone. + * + * @example + * + * var clone = bufferedBlockAlgorithm.clone(); + */ + clone: function() { + var clone = Base.clone.call(this); + clone._data = this._data.clone(); + return clone; + }, + _minBufferSize: 0 + }); + var Hasher = C_lib.Hasher = BufferedBlockAlgorithm.extend({ + /** + * Configuration options. + */ + cfg: Base.extend(), + /** + * Initializes a newly created hasher. + * + * @param {Object} cfg (Optional) The configuration options to use for this hash computation. + * + * @example + * + * var hasher = CryptoJS.algo.SHA256.create(); + */ + init: function(cfg) { + this.cfg = this.cfg.extend(cfg); + this.reset(); + }, + /** + * Resets this hasher to its initial state. + * + * @example + * + * hasher.reset(); + */ + reset: function() { + BufferedBlockAlgorithm.reset.call(this); + this._doReset(); + }, + /** + * Updates this hasher with a message. + * + * @param {WordArray|string} messageUpdate The message to append. + * + * @return {Hasher} This hasher. + * + * @example + * + * hasher.update('message'); + * hasher.update(wordArray); + */ + update: function(messageUpdate) { + this._append(messageUpdate); + this._process(); + return this; + }, + /** + * Finalizes the hash computation. + * Note that the finalize operation is effectively a destructive, read-once operation. + * + * @param {WordArray|string} messageUpdate (Optional) A final message update. + * + * @return {WordArray} The hash. + * + * @example + * + * var hash = hasher.finalize(); + * var hash = hasher.finalize('message'); + * var hash = hasher.finalize(wordArray); + */ + finalize: function(messageUpdate) { + if (messageUpdate) { + this._append(messageUpdate); + } + var hash = this._doFinalize(); + return hash; + }, + blockSize: 512 / 32, + /** + * Creates a shortcut function to a hasher's object interface. + * + * @param {Hasher} hasher The hasher to create a helper for. + * + * @return {Function} The shortcut function. + * + * @static + * + * @example + * + * var SHA256 = CryptoJS.lib.Hasher._createHelper(CryptoJS.algo.SHA256); + */ + _createHelper: function(hasher) { + return function(message, cfg) { + return new hasher.init(cfg).finalize(message); + }; + }, + /** + * Creates a shortcut function to the HMAC's object interface. + * + * @param {Hasher} hasher The hasher to use in this HMAC helper. + * + * @return {Function} The shortcut function. + * + * @static + * + * @example + * + * var HmacSHA256 = CryptoJS.lib.Hasher._createHmacHelper(CryptoJS.algo.SHA256); + */ + _createHmacHelper: function(hasher) { + return function(message, key) { + return new C_algo.HMAC.init(hasher, key).finalize(message); + }; + } + }); + var C_algo = C2.algo = {}; + return C2; + })(Math); + return CryptoJS2; + }); + } +}); + +// node_modules/crypto-js/x64-core.js +var require_x64_core = __commonJS({ + "node_modules/crypto-js/x64-core.js"(exports, module) { + (function(root, factory) { + if (typeof exports === "object") { + module.exports = exports = factory(require_core()); + } else if (typeof define === "function" && define.amd) { + define(["./core"], factory); + } else { + factory(root.CryptoJS); + } + })(exports, function(CryptoJS2) { + (function(undefined2) { + var C2 = CryptoJS2; + var C_lib = C2.lib; + var Base = C_lib.Base; + var X32WordArray = C_lib.WordArray; + var C_x64 = C2.x64 = {}; + var X64Word = C_x64.Word = Base.extend({ + /** + * Initializes a newly created 64-bit word. + * + * @param {number} high The high 32 bits. + * @param {number} low The low 32 bits. + * + * @example + * + * var x64Word = CryptoJS.x64.Word.create(0x00010203, 0x04050607); + */ + init: function(high, low) { + this.high = high; + this.low = low; + } + /** + * Bitwise NOTs this word. + * + * @return {X64Word} A new x64-Word object after negating. + * + * @example + * + * var negated = x64Word.not(); + */ + // not: function () { + // var high = ~this.high; + // var low = ~this.low; + // return X64Word.create(high, low); + // }, + /** + * Bitwise ANDs this word with the passed word. + * + * @param {X64Word} word The x64-Word to AND with this word. + * + * @return {X64Word} A new x64-Word object after ANDing. + * + * @example + * + * var anded = x64Word.and(anotherX64Word); + */ + // and: function (word) { + // var high = this.high & word.high; + // var low = this.low & word.low; + // return X64Word.create(high, low); + // }, + /** + * Bitwise ORs this word with the passed word. + * + * @param {X64Word} word The x64-Word to OR with this word. + * + * @return {X64Word} A new x64-Word object after ORing. + * + * @example + * + * var ored = x64Word.or(anotherX64Word); + */ + // or: function (word) { + // var high = this.high | word.high; + // var low = this.low | word.low; + // return X64Word.create(high, low); + // }, + /** + * Bitwise XORs this word with the passed word. + * + * @param {X64Word} word The x64-Word to XOR with this word. + * + * @return {X64Word} A new x64-Word object after XORing. + * + * @example + * + * var xored = x64Word.xor(anotherX64Word); + */ + // xor: function (word) { + // var high = this.high ^ word.high; + // var low = this.low ^ word.low; + // return X64Word.create(high, low); + // }, + /** + * Shifts this word n bits to the left. + * + * @param {number} n The number of bits to shift. + * + * @return {X64Word} A new x64-Word object after shifting. + * + * @example + * + * var shifted = x64Word.shiftL(25); + */ + // shiftL: function (n) { + // if (n < 32) { + // var high = (this.high << n) | (this.low >>> (32 - n)); + // var low = this.low << n; + // } else { + // var high = this.low << (n - 32); + // var low = 0; + // } + // return X64Word.create(high, low); + // }, + /** + * Shifts this word n bits to the right. + * + * @param {number} n The number of bits to shift. + * + * @return {X64Word} A new x64-Word object after shifting. + * + * @example + * + * var shifted = x64Word.shiftR(7); + */ + // shiftR: function (n) { + // if (n < 32) { + // var low = (this.low >>> n) | (this.high << (32 - n)); + // var high = this.high >>> n; + // } else { + // var low = this.high >>> (n - 32); + // var high = 0; + // } + // return X64Word.create(high, low); + // }, + /** + * Rotates this word n bits to the left. + * + * @param {number} n The number of bits to rotate. + * + * @return {X64Word} A new x64-Word object after rotating. + * + * @example + * + * var rotated = x64Word.rotL(25); + */ + // rotL: function (n) { + // return this.shiftL(n).or(this.shiftR(64 - n)); + // }, + /** + * Rotates this word n bits to the right. + * + * @param {number} n The number of bits to rotate. + * + * @return {X64Word} A new x64-Word object after rotating. + * + * @example + * + * var rotated = x64Word.rotR(7); + */ + // rotR: function (n) { + // return this.shiftR(n).or(this.shiftL(64 - n)); + // }, + /** + * Adds this word with the passed word. + * + * @param {X64Word} word The x64-Word to add with this word. + * + * @return {X64Word} A new x64-Word object after adding. + * + * @example + * + * var added = x64Word.add(anotherX64Word); + */ + // add: function (word) { + // var low = (this.low + word.low) | 0; + // var carry = (low >>> 0) < (this.low >>> 0) ? 1 : 0; + // var high = (this.high + word.high + carry) | 0; + // return X64Word.create(high, low); + // } + }); + var X64WordArray = C_x64.WordArray = Base.extend({ + /** + * Initializes a newly created word array. + * + * @param {Array} words (Optional) An array of CryptoJS.x64.Word objects. + * @param {number} sigBytes (Optional) The number of significant bytes in the words. + * + * @example + * + * var wordArray = CryptoJS.x64.WordArray.create(); + * + * var wordArray = CryptoJS.x64.WordArray.create([ + * CryptoJS.x64.Word.create(0x00010203, 0x04050607), + * CryptoJS.x64.Word.create(0x18191a1b, 0x1c1d1e1f) + * ]); + * + * var wordArray = CryptoJS.x64.WordArray.create([ + * CryptoJS.x64.Word.create(0x00010203, 0x04050607), + * CryptoJS.x64.Word.create(0x18191a1b, 0x1c1d1e1f) + * ], 10); + */ + init: function(words, sigBytes) { + words = this.words = words || []; + if (sigBytes != undefined2) { + this.sigBytes = sigBytes; + } else { + this.sigBytes = words.length * 8; + } + }, + /** + * Converts this 64-bit word array to a 32-bit word array. + * + * @return {CryptoJS.lib.WordArray} This word array's data as a 32-bit word array. + * + * @example + * + * var x32WordArray = x64WordArray.toX32(); + */ + toX32: function() { + var x64Words = this.words; + var x64WordsLength = x64Words.length; + var x32Words = []; + for (var i = 0; i < x64WordsLength; i++) { + var x64Word = x64Words[i]; + x32Words.push(x64Word.high); + x32Words.push(x64Word.low); + } + return X32WordArray.create(x32Words, this.sigBytes); + }, + /** + * Creates a copy of this word array. + * + * @return {X64WordArray} The clone. + * + * @example + * + * var clone = x64WordArray.clone(); + */ + clone: function() { + var clone = Base.clone.call(this); + var words = clone.words = this.words.slice(0); + var wordsLength = words.length; + for (var i = 0; i < wordsLength; i++) { + words[i] = words[i].clone(); + } + return clone; + } + }); + })(); + return CryptoJS2; + }); + } +}); + +// node_modules/crypto-js/lib-typedarrays.js +var require_lib_typedarrays = __commonJS({ + "node_modules/crypto-js/lib-typedarrays.js"(exports, module) { + (function(root, factory) { + if (typeof exports === "object") { + module.exports = exports = factory(require_core()); + } else if (typeof define === "function" && define.amd) { + define(["./core"], factory); + } else { + factory(root.CryptoJS); + } + })(exports, function(CryptoJS2) { + (function() { + if (typeof ArrayBuffer != "function") { + return; + } + var C2 = CryptoJS2; + var C_lib = C2.lib; + var WordArray = C_lib.WordArray; + var superInit = WordArray.init; + var subInit = WordArray.init = function(typedArray) { + if (typedArray instanceof ArrayBuffer) { + typedArray = new Uint8Array(typedArray); + } + if (typedArray instanceof Int8Array || typeof Uint8ClampedArray !== "undefined" && typedArray instanceof Uint8ClampedArray || typedArray instanceof Int16Array || typedArray instanceof Uint16Array || typedArray instanceof Int32Array || typedArray instanceof Uint32Array || typedArray instanceof Float32Array || typedArray instanceof Float64Array) { + typedArray = new Uint8Array(typedArray.buffer, typedArray.byteOffset, typedArray.byteLength); + } + if (typedArray instanceof Uint8Array) { + var typedArrayByteLength = typedArray.byteLength; + var words = []; + for (var i = 0; i < typedArrayByteLength; i++) { + words[i >>> 2] |= typedArray[i] << 24 - i % 4 * 8; + } + superInit.call(this, words, typedArrayByteLength); + } else { + superInit.apply(this, arguments); + } + }; + subInit.prototype = WordArray; + })(); + return CryptoJS2.lib.WordArray; + }); + } +}); + +// node_modules/crypto-js/enc-utf16.js +var require_enc_utf16 = __commonJS({ + "node_modules/crypto-js/enc-utf16.js"(exports, module) { + (function(root, factory) { + if (typeof exports === "object") { + module.exports = exports = factory(require_core()); + } else if (typeof define === "function" && define.amd) { + define(["./core"], factory); + } else { + factory(root.CryptoJS); + } + })(exports, function(CryptoJS2) { + (function() { + var C2 = CryptoJS2; + var C_lib = C2.lib; + var WordArray = C_lib.WordArray; + var C_enc = C2.enc; + var Utf16BE = C_enc.Utf16 = C_enc.Utf16BE = { + /** + * Converts a word array to a UTF-16 BE string. + * + * @param {WordArray} wordArray The word array. + * + * @return {string} The UTF-16 BE string. + * + * @static + * + * @example + * + * var utf16String = CryptoJS.enc.Utf16.stringify(wordArray); + */ + stringify: function(wordArray) { + var words = wordArray.words; + var sigBytes = wordArray.sigBytes; + var utf16Chars = []; + for (var i = 0; i < sigBytes; i += 2) { + var codePoint = words[i >>> 2] >>> 16 - i % 4 * 8 & 65535; + utf16Chars.push(String.fromCharCode(codePoint)); + } + return utf16Chars.join(""); + }, + /** + * Converts a UTF-16 BE string to a word array. + * + * @param {string} utf16Str The UTF-16 BE string. + * + * @return {WordArray} The word array. + * + * @static + * + * @example + * + * var wordArray = CryptoJS.enc.Utf16.parse(utf16String); + */ + parse: function(utf16Str) { + var utf16StrLength = utf16Str.length; + var words = []; + for (var i = 0; i < utf16StrLength; i++) { + words[i >>> 1] |= utf16Str.charCodeAt(i) << 16 - i % 2 * 16; + } + return WordArray.create(words, utf16StrLength * 2); + } + }; + C_enc.Utf16LE = { + /** + * Converts a word array to a UTF-16 LE string. + * + * @param {WordArray} wordArray The word array. + * + * @return {string} The UTF-16 LE string. + * + * @static + * + * @example + * + * var utf16Str = CryptoJS.enc.Utf16LE.stringify(wordArray); + */ + stringify: function(wordArray) { + var words = wordArray.words; + var sigBytes = wordArray.sigBytes; + var utf16Chars = []; + for (var i = 0; i < sigBytes; i += 2) { + var codePoint = swapEndian(words[i >>> 2] >>> 16 - i % 4 * 8 & 65535); + utf16Chars.push(String.fromCharCode(codePoint)); + } + return utf16Chars.join(""); + }, + /** + * Converts a UTF-16 LE string to a word array. + * + * @param {string} utf16Str The UTF-16 LE string. + * + * @return {WordArray} The word array. + * + * @static + * + * @example + * + * var wordArray = CryptoJS.enc.Utf16LE.parse(utf16Str); + */ + parse: function(utf16Str) { + var utf16StrLength = utf16Str.length; + var words = []; + for (var i = 0; i < utf16StrLength; i++) { + words[i >>> 1] |= swapEndian(utf16Str.charCodeAt(i) << 16 - i % 2 * 16); + } + return WordArray.create(words, utf16StrLength * 2); + } + }; + function swapEndian(word) { + return word << 8 & 4278255360 | word >>> 8 & 16711935; + } + })(); + return CryptoJS2.enc.Utf16; + }); + } +}); + +// node_modules/crypto-js/enc-base64.js +var require_enc_base64 = __commonJS({ + "node_modules/crypto-js/enc-base64.js"(exports, module) { + (function(root, factory) { + if (typeof exports === "object") { + module.exports = exports = factory(require_core()); + } else if (typeof define === "function" && define.amd) { + define(["./core"], factory); + } else { + factory(root.CryptoJS); + } + })(exports, function(CryptoJS2) { + (function() { + var C2 = CryptoJS2; + var C_lib = C2.lib; + var WordArray = C_lib.WordArray; + var C_enc = C2.enc; + var Base64 = C_enc.Base64 = { + /** + * Converts a word array to a Base64 string. + * + * @param {WordArray} wordArray The word array. + * + * @return {string} The Base64 string. + * + * @static + * + * @example + * + * var base64String = CryptoJS.enc.Base64.stringify(wordArray); + */ + stringify: function(wordArray) { + var words = wordArray.words; + var sigBytes = wordArray.sigBytes; + var map = this._map; + wordArray.clamp(); + var base64Chars = []; + for (var i = 0; i < sigBytes; i += 3) { + var byte1 = words[i >>> 2] >>> 24 - i % 4 * 8 & 255; + var byte2 = words[i + 1 >>> 2] >>> 24 - (i + 1) % 4 * 8 & 255; + var byte3 = words[i + 2 >>> 2] >>> 24 - (i + 2) % 4 * 8 & 255; + var triplet = byte1 << 16 | byte2 << 8 | byte3; + for (var j = 0; j < 4 && i + j * 0.75 < sigBytes; j++) { + base64Chars.push(map.charAt(triplet >>> 6 * (3 - j) & 63)); + } + } + var paddingChar = map.charAt(64); + if (paddingChar) { + while (base64Chars.length % 4) { + base64Chars.push(paddingChar); + } + } + return base64Chars.join(""); + }, + /** + * Converts a Base64 string to a word array. + * + * @param {string} base64Str The Base64 string. + * + * @return {WordArray} The word array. + * + * @static + * + * @example + * + * var wordArray = CryptoJS.enc.Base64.parse(base64String); + */ + parse: function(base64Str) { + var base64StrLength = base64Str.length; + var map = this._map; + var reverseMap = this._reverseMap; + if (!reverseMap) { + reverseMap = this._reverseMap = []; + for (var j = 0; j < map.length; j++) { + reverseMap[map.charCodeAt(j)] = j; + } + } + var paddingChar = map.charAt(64); + if (paddingChar) { + var paddingIndex = base64Str.indexOf(paddingChar); + if (paddingIndex !== -1) { + base64StrLength = paddingIndex; + } + } + return parseLoop(base64Str, base64StrLength, reverseMap); + }, + _map: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=" + }; + function parseLoop(base64Str, base64StrLength, reverseMap) { + var words = []; + var nBytes = 0; + for (var i = 0; i < base64StrLength; i++) { + if (i % 4) { + var bits1 = reverseMap[base64Str.charCodeAt(i - 1)] << i % 4 * 2; + var bits2 = reverseMap[base64Str.charCodeAt(i)] >>> 6 - i % 4 * 2; + var bitsCombined = bits1 | bits2; + words[nBytes >>> 2] |= bitsCombined << 24 - nBytes % 4 * 8; + nBytes++; + } + } + return WordArray.create(words, nBytes); + } + })(); + return CryptoJS2.enc.Base64; + }); + } +}); + +// node_modules/crypto-js/enc-base64url.js +var require_enc_base64url = __commonJS({ + "node_modules/crypto-js/enc-base64url.js"(exports, module) { + (function(root, factory) { + if (typeof exports === "object") { + module.exports = exports = factory(require_core()); + } else if (typeof define === "function" && define.amd) { + define(["./core"], factory); + } else { + factory(root.CryptoJS); + } + })(exports, function(CryptoJS2) { + (function() { + var C2 = CryptoJS2; + var C_lib = C2.lib; + var WordArray = C_lib.WordArray; + var C_enc = C2.enc; + var Base64url = C_enc.Base64url = { + /** + * Converts a word array to a Base64url string. + * + * @param {WordArray} wordArray The word array. + * + * @param {boolean} urlSafe Whether to use url safe + * + * @return {string} The Base64url string. + * + * @static + * + * @example + * + * var base64String = CryptoJS.enc.Base64url.stringify(wordArray); + */ + stringify: function(wordArray, urlSafe) { + if (urlSafe === void 0) { + urlSafe = true; + } + var words = wordArray.words; + var sigBytes = wordArray.sigBytes; + var map = urlSafe ? this._safe_map : this._map; + wordArray.clamp(); + var base64Chars = []; + for (var i = 0; i < sigBytes; i += 3) { + var byte1 = words[i >>> 2] >>> 24 - i % 4 * 8 & 255; + var byte2 = words[i + 1 >>> 2] >>> 24 - (i + 1) % 4 * 8 & 255; + var byte3 = words[i + 2 >>> 2] >>> 24 - (i + 2) % 4 * 8 & 255; + var triplet = byte1 << 16 | byte2 << 8 | byte3; + for (var j = 0; j < 4 && i + j * 0.75 < sigBytes; j++) { + base64Chars.push(map.charAt(triplet >>> 6 * (3 - j) & 63)); + } + } + var paddingChar = map.charAt(64); + if (paddingChar) { + while (base64Chars.length % 4) { + base64Chars.push(paddingChar); + } + } + return base64Chars.join(""); + }, + /** + * Converts a Base64url string to a word array. + * + * @param {string} base64Str The Base64url string. + * + * @param {boolean} urlSafe Whether to use url safe + * + * @return {WordArray} The word array. + * + * @static + * + * @example + * + * var wordArray = CryptoJS.enc.Base64url.parse(base64String); + */ + parse: function(base64Str, urlSafe) { + if (urlSafe === void 0) { + urlSafe = true; + } + var base64StrLength = base64Str.length; + var map = urlSafe ? this._safe_map : this._map; + var reverseMap = this._reverseMap; + if (!reverseMap) { + reverseMap = this._reverseMap = []; + for (var j = 0; j < map.length; j++) { + reverseMap[map.charCodeAt(j)] = j; + } + } + var paddingChar = map.charAt(64); + if (paddingChar) { + var paddingIndex = base64Str.indexOf(paddingChar); + if (paddingIndex !== -1) { + base64StrLength = paddingIndex; + } + } + return parseLoop(base64Str, base64StrLength, reverseMap); + }, + _map: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=", + _safe_map: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_" + }; + function parseLoop(base64Str, base64StrLength, reverseMap) { + var words = []; + var nBytes = 0; + for (var i = 0; i < base64StrLength; i++) { + if (i % 4) { + var bits1 = reverseMap[base64Str.charCodeAt(i - 1)] << i % 4 * 2; + var bits2 = reverseMap[base64Str.charCodeAt(i)] >>> 6 - i % 4 * 2; + var bitsCombined = bits1 | bits2; + words[nBytes >>> 2] |= bitsCombined << 24 - nBytes % 4 * 8; + nBytes++; + } + } + return WordArray.create(words, nBytes); + } + })(); + return CryptoJS2.enc.Base64url; + }); + } +}); + +// node_modules/crypto-js/md5.js +var require_md5 = __commonJS({ + "node_modules/crypto-js/md5.js"(exports, module) { + (function(root, factory) { + if (typeof exports === "object") { + module.exports = exports = factory(require_core()); + } else if (typeof define === "function" && define.amd) { + define(["./core"], factory); + } else { + factory(root.CryptoJS); + } + })(exports, function(CryptoJS2) { + (function(Math2) { + var C2 = CryptoJS2; + var C_lib = C2.lib; + var WordArray = C_lib.WordArray; + var Hasher = C_lib.Hasher; + var C_algo = C2.algo; + var T = []; + (function() { + for (var i = 0; i < 64; i++) { + T[i] = Math2.abs(Math2.sin(i + 1)) * 4294967296 | 0; + } + })(); + var MD5 = C_algo.MD5 = Hasher.extend({ + _doReset: function() { + this._hash = new WordArray.init([ + 1732584193, + 4023233417, + 2562383102, + 271733878 + ]); + }, + _doProcessBlock: function(M2, offset) { + for (var i = 0; i < 16; i++) { + var offset_i = offset + i; + var M_offset_i = M2[offset_i]; + M2[offset_i] = (M_offset_i << 8 | M_offset_i >>> 24) & 16711935 | (M_offset_i << 24 | M_offset_i >>> 8) & 4278255360; + } + var H = this._hash.words; + var M_offset_0 = M2[offset + 0]; + var M_offset_1 = M2[offset + 1]; + var M_offset_2 = M2[offset + 2]; + var M_offset_3 = M2[offset + 3]; + var M_offset_4 = M2[offset + 4]; + var M_offset_5 = M2[offset + 5]; + var M_offset_6 = M2[offset + 6]; + var M_offset_7 = M2[offset + 7]; + var M_offset_8 = M2[offset + 8]; + var M_offset_9 = M2[offset + 9]; + var M_offset_10 = M2[offset + 10]; + var M_offset_11 = M2[offset + 11]; + var M_offset_12 = M2[offset + 12]; + var M_offset_13 = M2[offset + 13]; + var M_offset_14 = M2[offset + 14]; + var M_offset_15 = M2[offset + 15]; + var a = H[0]; + var b = H[1]; + var c = H[2]; + var d = H[3]; + a = FF(a, b, c, d, M_offset_0, 7, T[0]); + d = FF(d, a, b, c, M_offset_1, 12, T[1]); + c = FF(c, d, a, b, M_offset_2, 17, T[2]); + b = FF(b, c, d, a, M_offset_3, 22, T[3]); + a = FF(a, b, c, d, M_offset_4, 7, T[4]); + d = FF(d, a, b, c, M_offset_5, 12, T[5]); + c = FF(c, d, a, b, M_offset_6, 17, T[6]); + b = FF(b, c, d, a, M_offset_7, 22, T[7]); + a = FF(a, b, c, d, M_offset_8, 7, T[8]); + d = FF(d, a, b, c, M_offset_9, 12, T[9]); + c = FF(c, d, a, b, M_offset_10, 17, T[10]); + b = FF(b, c, d, a, M_offset_11, 22, T[11]); + a = FF(a, b, c, d, M_offset_12, 7, T[12]); + d = FF(d, a, b, c, M_offset_13, 12, T[13]); + c = FF(c, d, a, b, M_offset_14, 17, T[14]); + b = FF(b, c, d, a, M_offset_15, 22, T[15]); + a = GG(a, b, c, d, M_offset_1, 5, T[16]); + d = GG(d, a, b, c, M_offset_6, 9, T[17]); + c = GG(c, d, a, b, M_offset_11, 14, T[18]); + b = GG(b, c, d, a, M_offset_0, 20, T[19]); + a = GG(a, b, c, d, M_offset_5, 5, T[20]); + d = GG(d, a, b, c, M_offset_10, 9, T[21]); + c = GG(c, d, a, b, M_offset_15, 14, T[22]); + b = GG(b, c, d, a, M_offset_4, 20, T[23]); + a = GG(a, b, c, d, M_offset_9, 5, T[24]); + d = GG(d, a, b, c, M_offset_14, 9, T[25]); + c = GG(c, d, a, b, M_offset_3, 14, T[26]); + b = GG(b, c, d, a, M_offset_8, 20, T[27]); + a = GG(a, b, c, d, M_offset_13, 5, T[28]); + d = GG(d, a, b, c, M_offset_2, 9, T[29]); + c = GG(c, d, a, b, M_offset_7, 14, T[30]); + b = GG(b, c, d, a, M_offset_12, 20, T[31]); + a = HH(a, b, c, d, M_offset_5, 4, T[32]); + d = HH(d, a, b, c, M_offset_8, 11, T[33]); + c = HH(c, d, a, b, M_offset_11, 16, T[34]); + b = HH(b, c, d, a, M_offset_14, 23, T[35]); + a = HH(a, b, c, d, M_offset_1, 4, T[36]); + d = HH(d, a, b, c, M_offset_4, 11, T[37]); + c = HH(c, d, a, b, M_offset_7, 16, T[38]); + b = HH(b, c, d, a, M_offset_10, 23, T[39]); + a = HH(a, b, c, d, M_offset_13, 4, T[40]); + d = HH(d, a, b, c, M_offset_0, 11, T[41]); + c = HH(c, d, a, b, M_offset_3, 16, T[42]); + b = HH(b, c, d, a, M_offset_6, 23, T[43]); + a = HH(a, b, c, d, M_offset_9, 4, T[44]); + d = HH(d, a, b, c, M_offset_12, 11, T[45]); + c = HH(c, d, a, b, M_offset_15, 16, T[46]); + b = HH(b, c, d, a, M_offset_2, 23, T[47]); + a = II(a, b, c, d, M_offset_0, 6, T[48]); + d = II(d, a, b, c, M_offset_7, 10, T[49]); + c = II(c, d, a, b, M_offset_14, 15, T[50]); + b = II(b, c, d, a, M_offset_5, 21, T[51]); + a = II(a, b, c, d, M_offset_12, 6, T[52]); + d = II(d, a, b, c, M_offset_3, 10, T[53]); + c = II(c, d, a, b, M_offset_10, 15, T[54]); + b = II(b, c, d, a, M_offset_1, 21, T[55]); + a = II(a, b, c, d, M_offset_8, 6, T[56]); + d = II(d, a, b, c, M_offset_15, 10, T[57]); + c = II(c, d, a, b, M_offset_6, 15, T[58]); + b = II(b, c, d, a, M_offset_13, 21, T[59]); + a = II(a, b, c, d, M_offset_4, 6, T[60]); + d = II(d, a, b, c, M_offset_11, 10, T[61]); + c = II(c, d, a, b, M_offset_2, 15, T[62]); + b = II(b, c, d, a, M_offset_9, 21, T[63]); + H[0] = H[0] + a | 0; + H[1] = H[1] + b | 0; + H[2] = H[2] + c | 0; + H[3] = H[3] + d | 0; + }, + _doFinalize: function() { + var data = this._data; + var dataWords = data.words; + var nBitsTotal = this._nDataBytes * 8; + var nBitsLeft = data.sigBytes * 8; + dataWords[nBitsLeft >>> 5] |= 128 << 24 - nBitsLeft % 32; + var nBitsTotalH = Math2.floor(nBitsTotal / 4294967296); + var nBitsTotalL = nBitsTotal; + dataWords[(nBitsLeft + 64 >>> 9 << 4) + 15] = (nBitsTotalH << 8 | nBitsTotalH >>> 24) & 16711935 | (nBitsTotalH << 24 | nBitsTotalH >>> 8) & 4278255360; + dataWords[(nBitsLeft + 64 >>> 9 << 4) + 14] = (nBitsTotalL << 8 | nBitsTotalL >>> 24) & 16711935 | (nBitsTotalL << 24 | nBitsTotalL >>> 8) & 4278255360; + data.sigBytes = (dataWords.length + 1) * 4; + this._process(); + var hash = this._hash; + var H = hash.words; + for (var i = 0; i < 4; i++) { + var H_i = H[i]; + H[i] = (H_i << 8 | H_i >>> 24) & 16711935 | (H_i << 24 | H_i >>> 8) & 4278255360; + } + return hash; + }, + clone: function() { + var clone = Hasher.clone.call(this); + clone._hash = this._hash.clone(); + return clone; + } + }); + function FF(a, b, c, d, x, s, t) { + var n = a + (b & c | ~b & d) + x + t; + return (n << s | n >>> 32 - s) + b; + } + function GG(a, b, c, d, x, s, t) { + var n = a + (b & d | c & ~d) + x + t; + return (n << s | n >>> 32 - s) + b; + } + function HH(a, b, c, d, x, s, t) { + var n = a + (b ^ c ^ d) + x + t; + return (n << s | n >>> 32 - s) + b; + } + function II(a, b, c, d, x, s, t) { + var n = a + (c ^ (b | ~d)) + x + t; + return (n << s | n >>> 32 - s) + b; + } + C2.MD5 = Hasher._createHelper(MD5); + C2.HmacMD5 = Hasher._createHmacHelper(MD5); + })(Math); + return CryptoJS2.MD5; + }); + } +}); + +// node_modules/crypto-js/sha1.js +var require_sha1 = __commonJS({ + "node_modules/crypto-js/sha1.js"(exports, module) { + (function(root, factory) { + if (typeof exports === "object") { + module.exports = exports = factory(require_core()); + } else if (typeof define === "function" && define.amd) { + define(["./core"], factory); + } else { + factory(root.CryptoJS); + } + })(exports, function(CryptoJS2) { + (function() { + var C2 = CryptoJS2; + var C_lib = C2.lib; + var WordArray = C_lib.WordArray; + var Hasher = C_lib.Hasher; + var C_algo = C2.algo; + var W2 = []; + var SHA1 = C_algo.SHA1 = Hasher.extend({ + _doReset: function() { + this._hash = new WordArray.init([ + 1732584193, + 4023233417, + 2562383102, + 271733878, + 3285377520 + ]); + }, + _doProcessBlock: function(M2, offset) { + var H = this._hash.words; + var a = H[0]; + var b = H[1]; + var c = H[2]; + var d = H[3]; + var e = H[4]; + for (var i = 0; i < 80; i++) { + if (i < 16) { + W2[i] = M2[offset + i] | 0; + } else { + var n = W2[i - 3] ^ W2[i - 8] ^ W2[i - 14] ^ W2[i - 16]; + W2[i] = n << 1 | n >>> 31; + } + var t = (a << 5 | a >>> 27) + e + W2[i]; + if (i < 20) { + t += (b & c | ~b & d) + 1518500249; + } else if (i < 40) { + t += (b ^ c ^ d) + 1859775393; + } else if (i < 60) { + t += (b & c | b & d | c & d) - 1894007588; + } else { + t += (b ^ c ^ d) - 899497514; + } + e = d; + d = c; + c = b << 30 | b >>> 2; + b = a; + a = t; + } + H[0] = H[0] + a | 0; + H[1] = H[1] + b | 0; + H[2] = H[2] + c | 0; + H[3] = H[3] + d | 0; + H[4] = H[4] + e | 0; + }, + _doFinalize: function() { + var data = this._data; + var dataWords = data.words; + var nBitsTotal = this._nDataBytes * 8; + var nBitsLeft = data.sigBytes * 8; + dataWords[nBitsLeft >>> 5] |= 128 << 24 - nBitsLeft % 32; + dataWords[(nBitsLeft + 64 >>> 9 << 4) + 14] = Math.floor(nBitsTotal / 4294967296); + dataWords[(nBitsLeft + 64 >>> 9 << 4) + 15] = nBitsTotal; + data.sigBytes = dataWords.length * 4; + this._process(); + return this._hash; + }, + clone: function() { + var clone = Hasher.clone.call(this); + clone._hash = this._hash.clone(); + return clone; + } + }); + C2.SHA1 = Hasher._createHelper(SHA1); + C2.HmacSHA1 = Hasher._createHmacHelper(SHA1); + })(); + return CryptoJS2.SHA1; + }); + } +}); + +// node_modules/crypto-js/sha256.js +var require_sha256 = __commonJS({ + "node_modules/crypto-js/sha256.js"(exports, module) { + (function(root, factory) { + if (typeof exports === "object") { + module.exports = exports = factory(require_core()); + } else if (typeof define === "function" && define.amd) { + define(["./core"], factory); + } else { + factory(root.CryptoJS); + } + })(exports, function(CryptoJS2) { + (function(Math2) { + var C2 = CryptoJS2; + var C_lib = C2.lib; + var WordArray = C_lib.WordArray; + var Hasher = C_lib.Hasher; + var C_algo = C2.algo; + var H = []; + var K = []; + (function() { + function isPrime(n2) { + var sqrtN = Math2.sqrt(n2); + for (var factor = 2; factor <= sqrtN; factor++) { + if (!(n2 % factor)) { + return false; + } + } + return true; + } + function getFractionalBits(n2) { + return (n2 - (n2 | 0)) * 4294967296 | 0; + } + var n = 2; + var nPrime = 0; + while (nPrime < 64) { + if (isPrime(n)) { + if (nPrime < 8) { + H[nPrime] = getFractionalBits(Math2.pow(n, 1 / 2)); + } + K[nPrime] = getFractionalBits(Math2.pow(n, 1 / 3)); + nPrime++; + } + n++; + } + })(); + var W2 = []; + var SHA2562 = C_algo.SHA256 = Hasher.extend({ + _doReset: function() { + this._hash = new WordArray.init(H.slice(0)); + }, + _doProcessBlock: function(M2, offset) { + var H2 = this._hash.words; + var a = H2[0]; + var b = H2[1]; + var c = H2[2]; + var d = H2[3]; + var e = H2[4]; + var f = H2[5]; + var g = H2[6]; + var h2 = H2[7]; + for (var i = 0; i < 64; i++) { + if (i < 16) { + W2[i] = M2[offset + i] | 0; + } else { + var gamma0x = W2[i - 15]; + var gamma0 = (gamma0x << 25 | gamma0x >>> 7) ^ (gamma0x << 14 | gamma0x >>> 18) ^ gamma0x >>> 3; + var gamma1x = W2[i - 2]; + var gamma1 = (gamma1x << 15 | gamma1x >>> 17) ^ (gamma1x << 13 | gamma1x >>> 19) ^ gamma1x >>> 10; + W2[i] = gamma0 + W2[i - 7] + gamma1 + W2[i - 16]; + } + var ch = e & f ^ ~e & g; + var maj = a & b ^ a & c ^ b & c; + var sigma0 = (a << 30 | a >>> 2) ^ (a << 19 | a >>> 13) ^ (a << 10 | a >>> 22); + var sigma1 = (e << 26 | e >>> 6) ^ (e << 21 | e >>> 11) ^ (e << 7 | e >>> 25); + var t1 = h2 + sigma1 + ch + K[i] + W2[i]; + var t2 = sigma0 + maj; + h2 = g; + g = f; + f = e; + e = d + t1 | 0; + d = c; + c = b; + b = a; + a = t1 + t2 | 0; + } + H2[0] = H2[0] + a | 0; + H2[1] = H2[1] + b | 0; + H2[2] = H2[2] + c | 0; + H2[3] = H2[3] + d | 0; + H2[4] = H2[4] + e | 0; + H2[5] = H2[5] + f | 0; + H2[6] = H2[6] + g | 0; + H2[7] = H2[7] + h2 | 0; + }, + _doFinalize: function() { + var data = this._data; + var dataWords = data.words; + var nBitsTotal = this._nDataBytes * 8; + var nBitsLeft = data.sigBytes * 8; + dataWords[nBitsLeft >>> 5] |= 128 << 24 - nBitsLeft % 32; + dataWords[(nBitsLeft + 64 >>> 9 << 4) + 14] = Math2.floor(nBitsTotal / 4294967296); + dataWords[(nBitsLeft + 64 >>> 9 << 4) + 15] = nBitsTotal; + data.sigBytes = dataWords.length * 4; + this._process(); + return this._hash; + }, + clone: function() { + var clone = Hasher.clone.call(this); + clone._hash = this._hash.clone(); + return clone; + } + }); + C2.SHA256 = Hasher._createHelper(SHA2562); + C2.HmacSHA256 = Hasher._createHmacHelper(SHA2562); + })(Math); + return CryptoJS2.SHA256; + }); + } +}); + +// node_modules/crypto-js/sha224.js +var require_sha224 = __commonJS({ + "node_modules/crypto-js/sha224.js"(exports, module) { + (function(root, factory, undef) { + if (typeof exports === "object") { + module.exports = exports = factory(require_core(), require_sha256()); + } else if (typeof define === "function" && define.amd) { + define(["./core", "./sha256"], factory); + } else { + factory(root.CryptoJS); + } + })(exports, function(CryptoJS2) { + (function() { + var C2 = CryptoJS2; + var C_lib = C2.lib; + var WordArray = C_lib.WordArray; + var C_algo = C2.algo; + var SHA2562 = C_algo.SHA256; + var SHA224 = C_algo.SHA224 = SHA2562.extend({ + _doReset: function() { + this._hash = new WordArray.init([ + 3238371032, + 914150663, + 812702999, + 4144912697, + 4290775857, + 1750603025, + 1694076839, + 3204075428 + ]); + }, + _doFinalize: function() { + var hash = SHA2562._doFinalize.call(this); + hash.sigBytes -= 4; + return hash; + } + }); + C2.SHA224 = SHA2562._createHelper(SHA224); + C2.HmacSHA224 = SHA2562._createHmacHelper(SHA224); + })(); + return CryptoJS2.SHA224; + }); + } +}); + +// node_modules/crypto-js/sha512.js +var require_sha512 = __commonJS({ + "node_modules/crypto-js/sha512.js"(exports, module) { + (function(root, factory, undef) { + if (typeof exports === "object") { + module.exports = exports = factory(require_core(), require_x64_core()); + } else if (typeof define === "function" && define.amd) { + define(["./core", "./x64-core"], factory); + } else { + factory(root.CryptoJS); + } + })(exports, function(CryptoJS2) { + (function() { + var C2 = CryptoJS2; + var C_lib = C2.lib; + var Hasher = C_lib.Hasher; + var C_x64 = C2.x64; + var X64Word = C_x64.Word; + var X64WordArray = C_x64.WordArray; + var C_algo = C2.algo; + function X64Word_create() { + return X64Word.create.apply(X64Word, arguments); + } + var K = [ + X64Word_create(1116352408, 3609767458), + X64Word_create(1899447441, 602891725), + X64Word_create(3049323471, 3964484399), + X64Word_create(3921009573, 2173295548), + X64Word_create(961987163, 4081628472), + X64Word_create(1508970993, 3053834265), + X64Word_create(2453635748, 2937671579), + X64Word_create(2870763221, 3664609560), + X64Word_create(3624381080, 2734883394), + X64Word_create(310598401, 1164996542), + X64Word_create(607225278, 1323610764), + X64Word_create(1426881987, 3590304994), + X64Word_create(1925078388, 4068182383), + X64Word_create(2162078206, 991336113), + X64Word_create(2614888103, 633803317), + X64Word_create(3248222580, 3479774868), + X64Word_create(3835390401, 2666613458), + X64Word_create(4022224774, 944711139), + X64Word_create(264347078, 2341262773), + X64Word_create(604807628, 2007800933), + X64Word_create(770255983, 1495990901), + X64Word_create(1249150122, 1856431235), + X64Word_create(1555081692, 3175218132), + X64Word_create(1996064986, 2198950837), + X64Word_create(2554220882, 3999719339), + X64Word_create(2821834349, 766784016), + X64Word_create(2952996808, 2566594879), + X64Word_create(3210313671, 3203337956), + X64Word_create(3336571891, 1034457026), + X64Word_create(3584528711, 2466948901), + X64Word_create(113926993, 3758326383), + X64Word_create(338241895, 168717936), + X64Word_create(666307205, 1188179964), + X64Word_create(773529912, 1546045734), + X64Word_create(1294757372, 1522805485), + X64Word_create(1396182291, 2643833823), + X64Word_create(1695183700, 2343527390), + X64Word_create(1986661051, 1014477480), + X64Word_create(2177026350, 1206759142), + X64Word_create(2456956037, 344077627), + X64Word_create(2730485921, 1290863460), + X64Word_create(2820302411, 3158454273), + X64Word_create(3259730800, 3505952657), + X64Word_create(3345764771, 106217008), + X64Word_create(3516065817, 3606008344), + X64Word_create(3600352804, 1432725776), + X64Word_create(4094571909, 1467031594), + X64Word_create(275423344, 851169720), + X64Word_create(430227734, 3100823752), + X64Word_create(506948616, 1363258195), + X64Word_create(659060556, 3750685593), + X64Word_create(883997877, 3785050280), + X64Word_create(958139571, 3318307427), + X64Word_create(1322822218, 3812723403), + X64Word_create(1537002063, 2003034995), + X64Word_create(1747873779, 3602036899), + X64Word_create(1955562222, 1575990012), + X64Word_create(2024104815, 1125592928), + X64Word_create(2227730452, 2716904306), + X64Word_create(2361852424, 442776044), + X64Word_create(2428436474, 593698344), + X64Word_create(2756734187, 3733110249), + X64Word_create(3204031479, 2999351573), + X64Word_create(3329325298, 3815920427), + X64Word_create(3391569614, 3928383900), + X64Word_create(3515267271, 566280711), + X64Word_create(3940187606, 3454069534), + X64Word_create(4118630271, 4000239992), + X64Word_create(116418474, 1914138554), + X64Word_create(174292421, 2731055270), + X64Word_create(289380356, 3203993006), + X64Word_create(460393269, 320620315), + X64Word_create(685471733, 587496836), + X64Word_create(852142971, 1086792851), + X64Word_create(1017036298, 365543100), + X64Word_create(1126000580, 2618297676), + X64Word_create(1288033470, 3409855158), + X64Word_create(1501505948, 4234509866), + X64Word_create(1607167915, 987167468), + X64Word_create(1816402316, 1246189591) + ]; + var W2 = []; + (function() { + for (var i = 0; i < 80; i++) { + W2[i] = X64Word_create(); + } + })(); + var SHA512 = C_algo.SHA512 = Hasher.extend({ + _doReset: function() { + this._hash = new X64WordArray.init([ + new X64Word.init(1779033703, 4089235720), + new X64Word.init(3144134277, 2227873595), + new X64Word.init(1013904242, 4271175723), + new X64Word.init(2773480762, 1595750129), + new X64Word.init(1359893119, 2917565137), + new X64Word.init(2600822924, 725511199), + new X64Word.init(528734635, 4215389547), + new X64Word.init(1541459225, 327033209) + ]); + }, + _doProcessBlock: function(M2, offset) { + var H = this._hash.words; + var H0 = H[0]; + var H1 = H[1]; + var H2 = H[2]; + var H3 = H[3]; + var H4 = H[4]; + var H5 = H[5]; + var H6 = H[6]; + var H7 = H[7]; + var H0h = H0.high; + var H0l = H0.low; + var H1h = H1.high; + var H1l = H1.low; + var H2h = H2.high; + var H2l = H2.low; + var H3h = H3.high; + var H3l = H3.low; + var H4h = H4.high; + var H4l = H4.low; + var H5h = H5.high; + var H5l = H5.low; + var H6h = H6.high; + var H6l = H6.low; + var H7h = H7.high; + var H7l = H7.low; + var ah = H0h; + var al = H0l; + var bh = H1h; + var bl = H1l; + var ch = H2h; + var cl = H2l; + var dh = H3h; + var dl = H3l; + var eh = H4h; + var el = H4l; + var fh = H5h; + var fl = H5l; + var gh = H6h; + var gl = H6l; + var hh = H7h; + var hl = H7l; + for (var i = 0; i < 80; i++) { + var Wil; + var Wih; + var Wi = W2[i]; + if (i < 16) { + Wih = Wi.high = M2[offset + i * 2] | 0; + Wil = Wi.low = M2[offset + i * 2 + 1] | 0; + } else { + var gamma0x = W2[i - 15]; + var gamma0xh = gamma0x.high; + var gamma0xl = gamma0x.low; + var gamma0h = (gamma0xh >>> 1 | gamma0xl << 31) ^ (gamma0xh >>> 8 | gamma0xl << 24) ^ gamma0xh >>> 7; + var gamma0l = (gamma0xl >>> 1 | gamma0xh << 31) ^ (gamma0xl >>> 8 | gamma0xh << 24) ^ (gamma0xl >>> 7 | gamma0xh << 25); + var gamma1x = W2[i - 2]; + var gamma1xh = gamma1x.high; + var gamma1xl = gamma1x.low; + var gamma1h = (gamma1xh >>> 19 | gamma1xl << 13) ^ (gamma1xh << 3 | gamma1xl >>> 29) ^ gamma1xh >>> 6; + var gamma1l = (gamma1xl >>> 19 | gamma1xh << 13) ^ (gamma1xl << 3 | gamma1xh >>> 29) ^ (gamma1xl >>> 6 | gamma1xh << 26); + var Wi7 = W2[i - 7]; + var Wi7h = Wi7.high; + var Wi7l = Wi7.low; + var Wi16 = W2[i - 16]; + var Wi16h = Wi16.high; + var Wi16l = Wi16.low; + Wil = gamma0l + Wi7l; + Wih = gamma0h + Wi7h + (Wil >>> 0 < gamma0l >>> 0 ? 1 : 0); + Wil = Wil + gamma1l; + Wih = Wih + gamma1h + (Wil >>> 0 < gamma1l >>> 0 ? 1 : 0); + Wil = Wil + Wi16l; + Wih = Wih + Wi16h + (Wil >>> 0 < Wi16l >>> 0 ? 1 : 0); + Wi.high = Wih; + Wi.low = Wil; + } + var chh = eh & fh ^ ~eh & gh; + var chl = el & fl ^ ~el & gl; + var majh = ah & bh ^ ah & ch ^ bh & ch; + var majl = al & bl ^ al & cl ^ bl & cl; + var sigma0h = (ah >>> 28 | al << 4) ^ (ah << 30 | al >>> 2) ^ (ah << 25 | al >>> 7); + var sigma0l = (al >>> 28 | ah << 4) ^ (al << 30 | ah >>> 2) ^ (al << 25 | ah >>> 7); + var sigma1h = (eh >>> 14 | el << 18) ^ (eh >>> 18 | el << 14) ^ (eh << 23 | el >>> 9); + var sigma1l = (el >>> 14 | eh << 18) ^ (el >>> 18 | eh << 14) ^ (el << 23 | eh >>> 9); + var Ki = K[i]; + var Kih = Ki.high; + var Kil = Ki.low; + var t1l = hl + sigma1l; + var t1h = hh + sigma1h + (t1l >>> 0 < hl >>> 0 ? 1 : 0); + var t1l = t1l + chl; + var t1h = t1h + chh + (t1l >>> 0 < chl >>> 0 ? 1 : 0); + var t1l = t1l + Kil; + var t1h = t1h + Kih + (t1l >>> 0 < Kil >>> 0 ? 1 : 0); + var t1l = t1l + Wil; + var t1h = t1h + Wih + (t1l >>> 0 < Wil >>> 0 ? 1 : 0); + var t2l = sigma0l + majl; + var t2h = sigma0h + majh + (t2l >>> 0 < sigma0l >>> 0 ? 1 : 0); + hh = gh; + hl = gl; + gh = fh; + gl = fl; + fh = eh; + fl = el; + el = dl + t1l | 0; + eh = dh + t1h + (el >>> 0 < dl >>> 0 ? 1 : 0) | 0; + dh = ch; + dl = cl; + ch = bh; + cl = bl; + bh = ah; + bl = al; + al = t1l + t2l | 0; + ah = t1h + t2h + (al >>> 0 < t1l >>> 0 ? 1 : 0) | 0; + } + H0l = H0.low = H0l + al; + H0.high = H0h + ah + (H0l >>> 0 < al >>> 0 ? 1 : 0); + H1l = H1.low = H1l + bl; + H1.high = H1h + bh + (H1l >>> 0 < bl >>> 0 ? 1 : 0); + H2l = H2.low = H2l + cl; + H2.high = H2h + ch + (H2l >>> 0 < cl >>> 0 ? 1 : 0); + H3l = H3.low = H3l + dl; + H3.high = H3h + dh + (H3l >>> 0 < dl >>> 0 ? 1 : 0); + H4l = H4.low = H4l + el; + H4.high = H4h + eh + (H4l >>> 0 < el >>> 0 ? 1 : 0); + H5l = H5.low = H5l + fl; + H5.high = H5h + fh + (H5l >>> 0 < fl >>> 0 ? 1 : 0); + H6l = H6.low = H6l + gl; + H6.high = H6h + gh + (H6l >>> 0 < gl >>> 0 ? 1 : 0); + H7l = H7.low = H7l + hl; + H7.high = H7h + hh + (H7l >>> 0 < hl >>> 0 ? 1 : 0); + }, + _doFinalize: function() { + var data = this._data; + var dataWords = data.words; + var nBitsTotal = this._nDataBytes * 8; + var nBitsLeft = data.sigBytes * 8; + dataWords[nBitsLeft >>> 5] |= 128 << 24 - nBitsLeft % 32; + dataWords[(nBitsLeft + 128 >>> 10 << 5) + 30] = Math.floor(nBitsTotal / 4294967296); + dataWords[(nBitsLeft + 128 >>> 10 << 5) + 31] = nBitsTotal; + data.sigBytes = dataWords.length * 4; + this._process(); + var hash = this._hash.toX32(); + return hash; + }, + clone: function() { + var clone = Hasher.clone.call(this); + clone._hash = this._hash.clone(); + return clone; + }, + blockSize: 1024 / 32 + }); + C2.SHA512 = Hasher._createHelper(SHA512); + C2.HmacSHA512 = Hasher._createHmacHelper(SHA512); + })(); + return CryptoJS2.SHA512; + }); + } +}); + +// node_modules/crypto-js/sha384.js +var require_sha384 = __commonJS({ + "node_modules/crypto-js/sha384.js"(exports, module) { + (function(root, factory, undef) { + if (typeof exports === "object") { + module.exports = exports = factory(require_core(), require_x64_core(), require_sha512()); + } else if (typeof define === "function" && define.amd) { + define(["./core", "./x64-core", "./sha512"], factory); + } else { + factory(root.CryptoJS); + } + })(exports, function(CryptoJS2) { + (function() { + var C2 = CryptoJS2; + var C_x64 = C2.x64; + var X64Word = C_x64.Word; + var X64WordArray = C_x64.WordArray; + var C_algo = C2.algo; + var SHA512 = C_algo.SHA512; + var SHA384 = C_algo.SHA384 = SHA512.extend({ + _doReset: function() { + this._hash = new X64WordArray.init([ + new X64Word.init(3418070365, 3238371032), + new X64Word.init(1654270250, 914150663), + new X64Word.init(2438529370, 812702999), + new X64Word.init(355462360, 4144912697), + new X64Word.init(1731405415, 4290775857), + new X64Word.init(2394180231, 1750603025), + new X64Word.init(3675008525, 1694076839), + new X64Word.init(1203062813, 3204075428) + ]); + }, + _doFinalize: function() { + var hash = SHA512._doFinalize.call(this); + hash.sigBytes -= 16; + return hash; + } + }); + C2.SHA384 = SHA512._createHelper(SHA384); + C2.HmacSHA384 = SHA512._createHmacHelper(SHA384); + })(); + return CryptoJS2.SHA384; + }); + } +}); + +// node_modules/crypto-js/sha3.js +var require_sha3 = __commonJS({ + "node_modules/crypto-js/sha3.js"(exports, module) { + (function(root, factory, undef) { + if (typeof exports === "object") { + module.exports = exports = factory(require_core(), require_x64_core()); + } else if (typeof define === "function" && define.amd) { + define(["./core", "./x64-core"], factory); + } else { + factory(root.CryptoJS); + } + })(exports, function(CryptoJS2) { + (function(Math2) { + var C2 = CryptoJS2; + var C_lib = C2.lib; + var WordArray = C_lib.WordArray; + var Hasher = C_lib.Hasher; + var C_x64 = C2.x64; + var X64Word = C_x64.Word; + var C_algo = C2.algo; + var RHO_OFFSETS = []; + var PI_INDEXES = []; + var ROUND_CONSTANTS = []; + (function() { + var x = 1, y = 0; + for (var t = 0; t < 24; t++) { + RHO_OFFSETS[x + 5 * y] = (t + 1) * (t + 2) / 2 % 64; + var newX = y % 5; + var newY = (2 * x + 3 * y) % 5; + x = newX; + y = newY; + } + for (var x = 0; x < 5; x++) { + for (var y = 0; y < 5; y++) { + PI_INDEXES[x + 5 * y] = y + (2 * x + 3 * y) % 5 * 5; + } + } + var LFSR = 1; + for (var i = 0; i < 24; i++) { + var roundConstantMsw = 0; + var roundConstantLsw = 0; + for (var j = 0; j < 7; j++) { + if (LFSR & 1) { + var bitPosition = (1 << j) - 1; + if (bitPosition < 32) { + roundConstantLsw ^= 1 << bitPosition; + } else { + roundConstantMsw ^= 1 << bitPosition - 32; + } + } + if (LFSR & 128) { + LFSR = LFSR << 1 ^ 113; + } else { + LFSR <<= 1; + } + } + ROUND_CONSTANTS[i] = X64Word.create(roundConstantMsw, roundConstantLsw); + } + })(); + var T = []; + (function() { + for (var i = 0; i < 25; i++) { + T[i] = X64Word.create(); + } + })(); + var SHA3 = C_algo.SHA3 = Hasher.extend({ + /** + * Configuration options. + * + * @property {number} outputLength + * The desired number of bits in the output hash. + * Only values permitted are: 224, 256, 384, 512. + * Default: 512 + */ + cfg: Hasher.cfg.extend({ + outputLength: 512 + }), + _doReset: function() { + var state = this._state = []; + for (var i = 0; i < 25; i++) { + state[i] = new X64Word.init(); + } + this.blockSize = (1600 - 2 * this.cfg.outputLength) / 32; + }, + _doProcessBlock: function(M2, offset) { + var state = this._state; + var nBlockSizeLanes = this.blockSize / 2; + for (var i = 0; i < nBlockSizeLanes; i++) { + var M2i = M2[offset + 2 * i]; + var M2i1 = M2[offset + 2 * i + 1]; + M2i = (M2i << 8 | M2i >>> 24) & 16711935 | (M2i << 24 | M2i >>> 8) & 4278255360; + M2i1 = (M2i1 << 8 | M2i1 >>> 24) & 16711935 | (M2i1 << 24 | M2i1 >>> 8) & 4278255360; + var lane = state[i]; + lane.high ^= M2i1; + lane.low ^= M2i; + } + for (var round = 0; round < 24; round++) { + for (var x = 0; x < 5; x++) { + var tMsw = 0, tLsw = 0; + for (var y = 0; y < 5; y++) { + var lane = state[x + 5 * y]; + tMsw ^= lane.high; + tLsw ^= lane.low; + } + var Tx = T[x]; + Tx.high = tMsw; + Tx.low = tLsw; + } + for (var x = 0; x < 5; x++) { + var Tx4 = T[(x + 4) % 5]; + var Tx1 = T[(x + 1) % 5]; + var Tx1Msw = Tx1.high; + var Tx1Lsw = Tx1.low; + var tMsw = Tx4.high ^ (Tx1Msw << 1 | Tx1Lsw >>> 31); + var tLsw = Tx4.low ^ (Tx1Lsw << 1 | Tx1Msw >>> 31); + for (var y = 0; y < 5; y++) { + var lane = state[x + 5 * y]; + lane.high ^= tMsw; + lane.low ^= tLsw; + } + } + for (var laneIndex = 1; laneIndex < 25; laneIndex++) { + var tMsw; + var tLsw; + var lane = state[laneIndex]; + var laneMsw = lane.high; + var laneLsw = lane.low; + var rhoOffset = RHO_OFFSETS[laneIndex]; + if (rhoOffset < 32) { + tMsw = laneMsw << rhoOffset | laneLsw >>> 32 - rhoOffset; + tLsw = laneLsw << rhoOffset | laneMsw >>> 32 - rhoOffset; + } else { + tMsw = laneLsw << rhoOffset - 32 | laneMsw >>> 64 - rhoOffset; + tLsw = laneMsw << rhoOffset - 32 | laneLsw >>> 64 - rhoOffset; + } + var TPiLane = T[PI_INDEXES[laneIndex]]; + TPiLane.high = tMsw; + TPiLane.low = tLsw; + } + var T0 = T[0]; + var state0 = state[0]; + T0.high = state0.high; + T0.low = state0.low; + for (var x = 0; x < 5; x++) { + for (var y = 0; y < 5; y++) { + var laneIndex = x + 5 * y; + var lane = state[laneIndex]; + var TLane = T[laneIndex]; + var Tx1Lane = T[(x + 1) % 5 + 5 * y]; + var Tx2Lane = T[(x + 2) % 5 + 5 * y]; + lane.high = TLane.high ^ ~Tx1Lane.high & Tx2Lane.high; + lane.low = TLane.low ^ ~Tx1Lane.low & Tx2Lane.low; + } + } + var lane = state[0]; + var roundConstant = ROUND_CONSTANTS[round]; + lane.high ^= roundConstant.high; + lane.low ^= roundConstant.low; + } + }, + _doFinalize: function() { + var data = this._data; + var dataWords = data.words; + var nBitsTotal = this._nDataBytes * 8; + var nBitsLeft = data.sigBytes * 8; + var blockSizeBits = this.blockSize * 32; + dataWords[nBitsLeft >>> 5] |= 1 << 24 - nBitsLeft % 32; + dataWords[(Math2.ceil((nBitsLeft + 1) / blockSizeBits) * blockSizeBits >>> 5) - 1] |= 128; + data.sigBytes = dataWords.length * 4; + this._process(); + var state = this._state; + var outputLengthBytes = this.cfg.outputLength / 8; + var outputLengthLanes = outputLengthBytes / 8; + var hashWords = []; + for (var i = 0; i < outputLengthLanes; i++) { + var lane = state[i]; + var laneMsw = lane.high; + var laneLsw = lane.low; + laneMsw = (laneMsw << 8 | laneMsw >>> 24) & 16711935 | (laneMsw << 24 | laneMsw >>> 8) & 4278255360; + laneLsw = (laneLsw << 8 | laneLsw >>> 24) & 16711935 | (laneLsw << 24 | laneLsw >>> 8) & 4278255360; + hashWords.push(laneLsw); + hashWords.push(laneMsw); + } + return new WordArray.init(hashWords, outputLengthBytes); + }, + clone: function() { + var clone = Hasher.clone.call(this); + var state = clone._state = this._state.slice(0); + for (var i = 0; i < 25; i++) { + state[i] = state[i].clone(); + } + return clone; + } + }); + C2.SHA3 = Hasher._createHelper(SHA3); + C2.HmacSHA3 = Hasher._createHmacHelper(SHA3); + })(Math); + return CryptoJS2.SHA3; + }); + } +}); + +// node_modules/crypto-js/ripemd160.js +var require_ripemd160 = __commonJS({ + "node_modules/crypto-js/ripemd160.js"(exports, module) { + (function(root, factory) { + if (typeof exports === "object") { + module.exports = exports = factory(require_core()); + } else if (typeof define === "function" && define.amd) { + define(["./core"], factory); + } else { + factory(root.CryptoJS); + } + })(exports, function(CryptoJS2) { + (function(Math2) { + var C2 = CryptoJS2; + var C_lib = C2.lib; + var WordArray = C_lib.WordArray; + var Hasher = C_lib.Hasher; + var C_algo = C2.algo; + var _zl = WordArray.create([ + 0, + 1, + 2, + 3, + 4, + 5, + 6, + 7, + 8, + 9, + 10, + 11, + 12, + 13, + 14, + 15, + 7, + 4, + 13, + 1, + 10, + 6, + 15, + 3, + 12, + 0, + 9, + 5, + 2, + 14, + 11, + 8, + 3, + 10, + 14, + 4, + 9, + 15, + 8, + 1, + 2, + 7, + 0, + 6, + 13, + 11, + 5, + 12, + 1, + 9, + 11, + 10, + 0, + 8, + 12, + 4, + 13, + 3, + 7, + 15, + 14, + 5, + 6, + 2, + 4, + 0, + 5, + 9, + 7, + 12, + 2, + 10, + 14, + 1, + 3, + 8, + 11, + 6, + 15, + 13 + ]); + var _zr = WordArray.create([ + 5, + 14, + 7, + 0, + 9, + 2, + 11, + 4, + 13, + 6, + 15, + 8, + 1, + 10, + 3, + 12, + 6, + 11, + 3, + 7, + 0, + 13, + 5, + 10, + 14, + 15, + 8, + 12, + 4, + 9, + 1, + 2, + 15, + 5, + 1, + 3, + 7, + 14, + 6, + 9, + 11, + 8, + 12, + 2, + 10, + 0, + 4, + 13, + 8, + 6, + 4, + 1, + 3, + 11, + 15, + 0, + 5, + 12, + 2, + 13, + 9, + 7, + 10, + 14, + 12, + 15, + 10, + 4, + 1, + 5, + 8, + 7, + 6, + 2, + 13, + 14, + 0, + 3, + 9, + 11 + ]); + var _sl = WordArray.create([ + 11, + 14, + 15, + 12, + 5, + 8, + 7, + 9, + 11, + 13, + 14, + 15, + 6, + 7, + 9, + 8, + 7, + 6, + 8, + 13, + 11, + 9, + 7, + 15, + 7, + 12, + 15, + 9, + 11, + 7, + 13, + 12, + 11, + 13, + 6, + 7, + 14, + 9, + 13, + 15, + 14, + 8, + 13, + 6, + 5, + 12, + 7, + 5, + 11, + 12, + 14, + 15, + 14, + 15, + 9, + 8, + 9, + 14, + 5, + 6, + 8, + 6, + 5, + 12, + 9, + 15, + 5, + 11, + 6, + 8, + 13, + 12, + 5, + 12, + 13, + 14, + 11, + 8, + 5, + 6 + ]); + var _sr = WordArray.create([ + 8, + 9, + 9, + 11, + 13, + 15, + 15, + 5, + 7, + 7, + 8, + 11, + 14, + 14, + 12, + 6, + 9, + 13, + 15, + 7, + 12, + 8, + 9, + 11, + 7, + 7, + 12, + 7, + 6, + 15, + 13, + 11, + 9, + 7, + 15, + 11, + 8, + 6, + 6, + 14, + 12, + 13, + 5, + 14, + 13, + 13, + 7, + 5, + 15, + 5, + 8, + 11, + 14, + 14, + 6, + 14, + 6, + 9, + 12, + 9, + 12, + 5, + 15, + 8, + 8, + 5, + 12, + 9, + 12, + 5, + 14, + 6, + 8, + 13, + 6, + 5, + 15, + 13, + 11, + 11 + ]); + var _hl = WordArray.create([0, 1518500249, 1859775393, 2400959708, 2840853838]); + var _hr = WordArray.create([1352829926, 1548603684, 1836072691, 2053994217, 0]); + var RIPEMD160 = C_algo.RIPEMD160 = Hasher.extend({ + _doReset: function() { + this._hash = WordArray.create([1732584193, 4023233417, 2562383102, 271733878, 3285377520]); + }, + _doProcessBlock: function(M2, offset) { + for (var i = 0; i < 16; i++) { + var offset_i = offset + i; + var M_offset_i = M2[offset_i]; + M2[offset_i] = (M_offset_i << 8 | M_offset_i >>> 24) & 16711935 | (M_offset_i << 24 | M_offset_i >>> 8) & 4278255360; + } + var H = this._hash.words; + var hl = _hl.words; + var hr = _hr.words; + var zl = _zl.words; + var zr = _zr.words; + var sl = _sl.words; + var sr = _sr.words; + var al, bl, cl, dl, el; + var ar, br, cr2, dr, er; + ar = al = H[0]; + br = bl = H[1]; + cr2 = cl = H[2]; + dr = dl = H[3]; + er = el = H[4]; + var t; + for (var i = 0; i < 80; i += 1) { + t = al + M2[offset + zl[i]] | 0; + if (i < 16) { + t += f1(bl, cl, dl) + hl[0]; + } else if (i < 32) { + t += f2(bl, cl, dl) + hl[1]; + } else if (i < 48) { + t += f3(bl, cl, dl) + hl[2]; + } else if (i < 64) { + t += f4(bl, cl, dl) + hl[3]; + } else { + t += f5(bl, cl, dl) + hl[4]; + } + t = t | 0; + t = rotl(t, sl[i]); + t = t + el | 0; + al = el; + el = dl; + dl = rotl(cl, 10); + cl = bl; + bl = t; + t = ar + M2[offset + zr[i]] | 0; + if (i < 16) { + t += f5(br, cr2, dr) + hr[0]; + } else if (i < 32) { + t += f4(br, cr2, dr) + hr[1]; + } else if (i < 48) { + t += f3(br, cr2, dr) + hr[2]; + } else if (i < 64) { + t += f2(br, cr2, dr) + hr[3]; + } else { + t += f1(br, cr2, dr) + hr[4]; + } + t = t | 0; + t = rotl(t, sr[i]); + t = t + er | 0; + ar = er; + er = dr; + dr = rotl(cr2, 10); + cr2 = br; + br = t; + } + t = H[1] + cl + dr | 0; + H[1] = H[2] + dl + er | 0; + H[2] = H[3] + el + ar | 0; + H[3] = H[4] + al + br | 0; + H[4] = H[0] + bl + cr2 | 0; + H[0] = t; + }, + _doFinalize: function() { + var data = this._data; + var dataWords = data.words; + var nBitsTotal = this._nDataBytes * 8; + var nBitsLeft = data.sigBytes * 8; + dataWords[nBitsLeft >>> 5] |= 128 << 24 - nBitsLeft % 32; + dataWords[(nBitsLeft + 64 >>> 9 << 4) + 14] = (nBitsTotal << 8 | nBitsTotal >>> 24) & 16711935 | (nBitsTotal << 24 | nBitsTotal >>> 8) & 4278255360; + data.sigBytes = (dataWords.length + 1) * 4; + this._process(); + var hash = this._hash; + var H = hash.words; + for (var i = 0; i < 5; i++) { + var H_i = H[i]; + H[i] = (H_i << 8 | H_i >>> 24) & 16711935 | (H_i << 24 | H_i >>> 8) & 4278255360; + } + return hash; + }, + clone: function() { + var clone = Hasher.clone.call(this); + clone._hash = this._hash.clone(); + return clone; + } + }); + function f1(x, y, z) { + return x ^ y ^ z; + } + function f2(x, y, z) { + return x & y | ~x & z; + } + function f3(x, y, z) { + return (x | ~y) ^ z; + } + function f4(x, y, z) { + return x & z | y & ~z; + } + function f5(x, y, z) { + return x ^ (y | ~z); + } + function rotl(x, n) { + return x << n | x >>> 32 - n; + } + C2.RIPEMD160 = Hasher._createHelper(RIPEMD160); + C2.HmacRIPEMD160 = Hasher._createHmacHelper(RIPEMD160); + })(Math); + return CryptoJS2.RIPEMD160; + }); + } +}); + +// node_modules/crypto-js/hmac.js +var require_hmac = __commonJS({ + "node_modules/crypto-js/hmac.js"(exports, module) { + (function(root, factory) { + if (typeof exports === "object") { + module.exports = exports = factory(require_core()); + } else if (typeof define === "function" && define.amd) { + define(["./core"], factory); + } else { + factory(root.CryptoJS); + } + })(exports, function(CryptoJS2) { + (function() { + var C2 = CryptoJS2; + var C_lib = C2.lib; + var Base = C_lib.Base; + var C_enc = C2.enc; + var Utf8 = C_enc.Utf8; + var C_algo = C2.algo; + var HMAC = C_algo.HMAC = Base.extend({ + /** + * Initializes a newly created HMAC. + * + * @param {Hasher} hasher The hash algorithm to use. + * @param {WordArray|string} key The secret key. + * + * @example + * + * var hmacHasher = CryptoJS.algo.HMAC.create(CryptoJS.algo.SHA256, key); + */ + init: function(hasher, key) { + hasher = this._hasher = new hasher.init(); + if (typeof key == "string") { + key = Utf8.parse(key); + } + var hasherBlockSize = hasher.blockSize; + var hasherBlockSizeBytes = hasherBlockSize * 4; + if (key.sigBytes > hasherBlockSizeBytes) { + key = hasher.finalize(key); + } + key.clamp(); + var oKey = this._oKey = key.clone(); + var iKey = this._iKey = key.clone(); + var oKeyWords = oKey.words; + var iKeyWords = iKey.words; + for (var i = 0; i < hasherBlockSize; i++) { + oKeyWords[i] ^= 1549556828; + iKeyWords[i] ^= 909522486; + } + oKey.sigBytes = iKey.sigBytes = hasherBlockSizeBytes; + this.reset(); + }, + /** + * Resets this HMAC to its initial state. + * + * @example + * + * hmacHasher.reset(); + */ + reset: function() { + var hasher = this._hasher; + hasher.reset(); + hasher.update(this._iKey); + }, + /** + * Updates this HMAC with a message. + * + * @param {WordArray|string} messageUpdate The message to append. + * + * @return {HMAC} This HMAC instance. + * + * @example + * + * hmacHasher.update('message'); + * hmacHasher.update(wordArray); + */ + update: function(messageUpdate) { + this._hasher.update(messageUpdate); + return this; + }, + /** + * Finalizes the HMAC computation. + * Note that the finalize operation is effectively a destructive, read-once operation. + * + * @param {WordArray|string} messageUpdate (Optional) A final message update. + * + * @return {WordArray} The HMAC. + * + * @example + * + * var hmac = hmacHasher.finalize(); + * var hmac = hmacHasher.finalize('message'); + * var hmac = hmacHasher.finalize(wordArray); + */ + finalize: function(messageUpdate) { + var hasher = this._hasher; + var innerHash = hasher.finalize(messageUpdate); + hasher.reset(); + var hmac = hasher.finalize(this._oKey.clone().concat(innerHash)); + return hmac; + } + }); + })(); + }); + } +}); + +// node_modules/crypto-js/pbkdf2.js +var require_pbkdf2 = __commonJS({ + "node_modules/crypto-js/pbkdf2.js"(exports, module) { + (function(root, factory, undef) { + if (typeof exports === "object") { + module.exports = exports = factory(require_core(), require_sha256(), require_hmac()); + } else if (typeof define === "function" && define.amd) { + define(["./core", "./sha256", "./hmac"], factory); + } else { + factory(root.CryptoJS); + } + })(exports, function(CryptoJS2) { + (function() { + var C2 = CryptoJS2; + var C_lib = C2.lib; + var Base = C_lib.Base; + var WordArray = C_lib.WordArray; + var C_algo = C2.algo; + var SHA2562 = C_algo.SHA256; + var HMAC = C_algo.HMAC; + var PBKDF2 = C_algo.PBKDF2 = Base.extend({ + /** + * Configuration options. + * + * @property {number} keySize The key size in words to generate. Default: 4 (128 bits) + * @property {Hasher} hasher The hasher to use. Default: SHA256 + * @property {number} iterations The number of iterations to perform. Default: 250000 + */ + cfg: Base.extend({ + keySize: 128 / 32, + hasher: SHA2562, + iterations: 25e4 + }), + /** + * Initializes a newly created key derivation function. + * + * @param {Object} cfg (Optional) The configuration options to use for the derivation. + * + * @example + * + * var kdf = CryptoJS.algo.PBKDF2.create(); + * var kdf = CryptoJS.algo.PBKDF2.create({ keySize: 8 }); + * var kdf = CryptoJS.algo.PBKDF2.create({ keySize: 8, iterations: 1000 }); + */ + init: function(cfg) { + this.cfg = this.cfg.extend(cfg); + }, + /** + * Computes the Password-Based Key Derivation Function 2. + * + * @param {WordArray|string} password The password. + * @param {WordArray|string} salt A salt. + * + * @return {WordArray} The derived key. + * + * @example + * + * var key = kdf.compute(password, salt); + */ + compute: function(password, salt) { + var cfg = this.cfg; + var hmac = HMAC.create(cfg.hasher, password); + var derivedKey = WordArray.create(); + var blockIndex = WordArray.create([1]); + var derivedKeyWords = derivedKey.words; + var blockIndexWords = blockIndex.words; + var keySize = cfg.keySize; + var iterations = cfg.iterations; + while (derivedKeyWords.length < keySize) { + var block = hmac.update(salt).finalize(blockIndex); + hmac.reset(); + var blockWords = block.words; + var blockWordsLength = blockWords.length; + var intermediate = block; + for (var i = 1; i < iterations; i++) { + intermediate = hmac.finalize(intermediate); + hmac.reset(); + var intermediateWords = intermediate.words; + for (var j = 0; j < blockWordsLength; j++) { + blockWords[j] ^= intermediateWords[j]; + } + } + derivedKey.concat(block); + blockIndexWords[0]++; + } + derivedKey.sigBytes = keySize * 4; + return derivedKey; + } + }); + C2.PBKDF2 = function(password, salt, cfg) { + return PBKDF2.create(cfg).compute(password, salt); + }; + })(); + return CryptoJS2.PBKDF2; + }); + } +}); + +// node_modules/crypto-js/evpkdf.js +var require_evpkdf = __commonJS({ + "node_modules/crypto-js/evpkdf.js"(exports, module) { + (function(root, factory, undef) { + if (typeof exports === "object") { + module.exports = exports = factory(require_core(), require_sha1(), require_hmac()); + } else if (typeof define === "function" && define.amd) { + define(["./core", "./sha1", "./hmac"], factory); + } else { + factory(root.CryptoJS); + } + })(exports, function(CryptoJS2) { + (function() { + var C2 = CryptoJS2; + var C_lib = C2.lib; + var Base = C_lib.Base; + var WordArray = C_lib.WordArray; + var C_algo = C2.algo; + var MD5 = C_algo.MD5; + var EvpKDF = C_algo.EvpKDF = Base.extend({ + /** + * Configuration options. + * + * @property {number} keySize The key size in words to generate. Default: 4 (128 bits) + * @property {Hasher} hasher The hash algorithm to use. Default: MD5 + * @property {number} iterations The number of iterations to perform. Default: 1 + */ + cfg: Base.extend({ + keySize: 128 / 32, + hasher: MD5, + iterations: 1 + }), + /** + * Initializes a newly created key derivation function. + * + * @param {Object} cfg (Optional) The configuration options to use for the derivation. + * + * @example + * + * var kdf = CryptoJS.algo.EvpKDF.create(); + * var kdf = CryptoJS.algo.EvpKDF.create({ keySize: 8 }); + * var kdf = CryptoJS.algo.EvpKDF.create({ keySize: 8, iterations: 1000 }); + */ + init: function(cfg) { + this.cfg = this.cfg.extend(cfg); + }, + /** + * Derives a key from a password. + * + * @param {WordArray|string} password The password. + * @param {WordArray|string} salt A salt. + * + * @return {WordArray} The derived key. + * + * @example + * + * var key = kdf.compute(password, salt); + */ + compute: function(password, salt) { + var block; + var cfg = this.cfg; + var hasher = cfg.hasher.create(); + var derivedKey = WordArray.create(); + var derivedKeyWords = derivedKey.words; + var keySize = cfg.keySize; + var iterations = cfg.iterations; + while (derivedKeyWords.length < keySize) { + if (block) { + hasher.update(block); + } + block = hasher.update(password).finalize(salt); + hasher.reset(); + for (var i = 1; i < iterations; i++) { + block = hasher.finalize(block); + hasher.reset(); + } + derivedKey.concat(block); + } + derivedKey.sigBytes = keySize * 4; + return derivedKey; + } + }); + C2.EvpKDF = function(password, salt, cfg) { + return EvpKDF.create(cfg).compute(password, salt); + }; + })(); + return CryptoJS2.EvpKDF; + }); + } +}); + +// node_modules/crypto-js/cipher-core.js +var require_cipher_core = __commonJS({ + "node_modules/crypto-js/cipher-core.js"(exports, module) { + (function(root, factory, undef) { + if (typeof exports === "object") { + module.exports = exports = factory(require_core(), require_evpkdf()); + } else if (typeof define === "function" && define.amd) { + define(["./core", "./evpkdf"], factory); + } else { + factory(root.CryptoJS); + } + })(exports, function(CryptoJS2) { + CryptoJS2.lib.Cipher || (function(undefined2) { + var C2 = CryptoJS2; + var C_lib = C2.lib; + var Base = C_lib.Base; + var WordArray = C_lib.WordArray; + var BufferedBlockAlgorithm = C_lib.BufferedBlockAlgorithm; + var C_enc = C2.enc; + var Utf8 = C_enc.Utf8; + var Base64 = C_enc.Base64; + var C_algo = C2.algo; + var EvpKDF = C_algo.EvpKDF; + var Cipher = C_lib.Cipher = BufferedBlockAlgorithm.extend({ + /** + * Configuration options. + * + * @property {WordArray} iv The IV to use for this operation. + */ + cfg: Base.extend(), + /** + * Creates this cipher in encryption mode. + * + * @param {WordArray} key The key. + * @param {Object} cfg (Optional) The configuration options to use for this operation. + * + * @return {Cipher} A cipher instance. + * + * @static + * + * @example + * + * var cipher = CryptoJS.algo.AES.createEncryptor(keyWordArray, { iv: ivWordArray }); + */ + createEncryptor: function(key, cfg) { + return this.create(this._ENC_XFORM_MODE, key, cfg); + }, + /** + * Creates this cipher in decryption mode. + * + * @param {WordArray} key The key. + * @param {Object} cfg (Optional) The configuration options to use for this operation. + * + * @return {Cipher} A cipher instance. + * + * @static + * + * @example + * + * var cipher = CryptoJS.algo.AES.createDecryptor(keyWordArray, { iv: ivWordArray }); + */ + createDecryptor: function(key, cfg) { + return this.create(this._DEC_XFORM_MODE, key, cfg); + }, + /** + * Initializes a newly created cipher. + * + * @param {number} xformMode Either the encryption or decryption transormation mode constant. + * @param {WordArray} key The key. + * @param {Object} cfg (Optional) The configuration options to use for this operation. + * + * @example + * + * var cipher = CryptoJS.algo.AES.create(CryptoJS.algo.AES._ENC_XFORM_MODE, keyWordArray, { iv: ivWordArray }); + */ + init: function(xformMode, key, cfg) { + this.cfg = this.cfg.extend(cfg); + this._xformMode = xformMode; + this._key = key; + this.reset(); + }, + /** + * Resets this cipher to its initial state. + * + * @example + * + * cipher.reset(); + */ + reset: function() { + BufferedBlockAlgorithm.reset.call(this); + this._doReset(); + }, + /** + * Adds data to be encrypted or decrypted. + * + * @param {WordArray|string} dataUpdate The data to encrypt or decrypt. + * + * @return {WordArray} The data after processing. + * + * @example + * + * var encrypted = cipher.process('data'); + * var encrypted = cipher.process(wordArray); + */ + process: function(dataUpdate) { + this._append(dataUpdate); + return this._process(); + }, + /** + * Finalizes the encryption or decryption process. + * Note that the finalize operation is effectively a destructive, read-once operation. + * + * @param {WordArray|string} dataUpdate The final data to encrypt or decrypt. + * + * @return {WordArray} The data after final processing. + * + * @example + * + * var encrypted = cipher.finalize(); + * var encrypted = cipher.finalize('data'); + * var encrypted = cipher.finalize(wordArray); + */ + finalize: function(dataUpdate) { + if (dataUpdate) { + this._append(dataUpdate); + } + var finalProcessedData = this._doFinalize(); + return finalProcessedData; + }, + keySize: 128 / 32, + ivSize: 128 / 32, + _ENC_XFORM_MODE: 1, + _DEC_XFORM_MODE: 2, + /** + * Creates shortcut functions to a cipher's object interface. + * + * @param {Cipher} cipher The cipher to create a helper for. + * + * @return {Object} An object with encrypt and decrypt shortcut functions. + * + * @static + * + * @example + * + * var AES = CryptoJS.lib.Cipher._createHelper(CryptoJS.algo.AES); + */ + _createHelper: /* @__PURE__ */ (function() { + function selectCipherStrategy(key) { + if (typeof key == "string") { + return PasswordBasedCipher; + } else { + return SerializableCipher; + } + } + return function(cipher) { + return { + encrypt: function(message, key, cfg) { + return selectCipherStrategy(key).encrypt(cipher, message, key, cfg); + }, + decrypt: function(ciphertext, key, cfg) { + return selectCipherStrategy(key).decrypt(cipher, ciphertext, key, cfg); + } + }; + }; + })() + }); + var StreamCipher = C_lib.StreamCipher = Cipher.extend({ + _doFinalize: function() { + var finalProcessedBlocks = this._process(true); + return finalProcessedBlocks; + }, + blockSize: 1 + }); + var C_mode = C2.mode = {}; + var BlockCipherMode = C_lib.BlockCipherMode = Base.extend({ + /** + * Creates this mode for encryption. + * + * @param {Cipher} cipher A block cipher instance. + * @param {Array} iv The IV words. + * + * @static + * + * @example + * + * var mode = CryptoJS.mode.CBC.createEncryptor(cipher, iv.words); + */ + createEncryptor: function(cipher, iv) { + return this.Encryptor.create(cipher, iv); + }, + /** + * Creates this mode for decryption. + * + * @param {Cipher} cipher A block cipher instance. + * @param {Array} iv The IV words. + * + * @static + * + * @example + * + * var mode = CryptoJS.mode.CBC.createDecryptor(cipher, iv.words); + */ + createDecryptor: function(cipher, iv) { + return this.Decryptor.create(cipher, iv); + }, + /** + * Initializes a newly created mode. + * + * @param {Cipher} cipher A block cipher instance. + * @param {Array} iv The IV words. + * + * @example + * + * var mode = CryptoJS.mode.CBC.Encryptor.create(cipher, iv.words); + */ + init: function(cipher, iv) { + this._cipher = cipher; + this._iv = iv; + } + }); + var CBC = C_mode.CBC = (function() { + var CBC2 = BlockCipherMode.extend(); + CBC2.Encryptor = CBC2.extend({ + /** + * Processes the data block at offset. + * + * @param {Array} words The data words to operate on. + * @param {number} offset The offset where the block starts. + * + * @example + * + * mode.processBlock(data.words, offset); + */ + processBlock: function(words, offset) { + var cipher = this._cipher; + var blockSize = cipher.blockSize; + xorBlock.call(this, words, offset, blockSize); + cipher.encryptBlock(words, offset); + this._prevBlock = words.slice(offset, offset + blockSize); + } + }); + CBC2.Decryptor = CBC2.extend({ + /** + * Processes the data block at offset. + * + * @param {Array} words The data words to operate on. + * @param {number} offset The offset where the block starts. + * + * @example + * + * mode.processBlock(data.words, offset); + */ + processBlock: function(words, offset) { + var cipher = this._cipher; + var blockSize = cipher.blockSize; + var thisBlock = words.slice(offset, offset + blockSize); + cipher.decryptBlock(words, offset); + xorBlock.call(this, words, offset, blockSize); + this._prevBlock = thisBlock; + } + }); + function xorBlock(words, offset, blockSize) { + var block; + var iv = this._iv; + if (iv) { + block = iv; + this._iv = undefined2; + } else { + block = this._prevBlock; + } + for (var i = 0; i < blockSize; i++) { + words[offset + i] ^= block[i]; + } + } + return CBC2; + })(); + var C_pad = C2.pad = {}; + var Pkcs7 = C_pad.Pkcs7 = { + /** + * Pads data using the algorithm defined in PKCS #5/7. + * + * @param {WordArray} data The data to pad. + * @param {number} blockSize The multiple that the data should be padded to. + * + * @static + * + * @example + * + * CryptoJS.pad.Pkcs7.pad(wordArray, 4); + */ + pad: function(data, blockSize) { + var blockSizeBytes = blockSize * 4; + var nPaddingBytes = blockSizeBytes - data.sigBytes % blockSizeBytes; + var paddingWord = nPaddingBytes << 24 | nPaddingBytes << 16 | nPaddingBytes << 8 | nPaddingBytes; + var paddingWords = []; + for (var i = 0; i < nPaddingBytes; i += 4) { + paddingWords.push(paddingWord); + } + var padding = WordArray.create(paddingWords, nPaddingBytes); + data.concat(padding); + }, + /** + * Unpads data that had been padded using the algorithm defined in PKCS #5/7. + * + * @param {WordArray} data The data to unpad. + * + * @static + * + * @example + * + * CryptoJS.pad.Pkcs7.unpad(wordArray); + */ + unpad: function(data) { + var nPaddingBytes = data.words[data.sigBytes - 1 >>> 2] & 255; + data.sigBytes -= nPaddingBytes; + } + }; + var BlockCipher = C_lib.BlockCipher = Cipher.extend({ + /** + * Configuration options. + * + * @property {Mode} mode The block mode to use. Default: CBC + * @property {Padding} padding The padding strategy to use. Default: Pkcs7 + */ + cfg: Cipher.cfg.extend({ + mode: CBC, + padding: Pkcs7 + }), + reset: function() { + var modeCreator; + Cipher.reset.call(this); + var cfg = this.cfg; + var iv = cfg.iv; + var mode2 = cfg.mode; + if (this._xformMode == this._ENC_XFORM_MODE) { + modeCreator = mode2.createEncryptor; + } else { + modeCreator = mode2.createDecryptor; + this._minBufferSize = 1; + } + if (this._mode && this._mode.__creator == modeCreator) { + this._mode.init(this, iv && iv.words); + } else { + this._mode = modeCreator.call(mode2, this, iv && iv.words); + this._mode.__creator = modeCreator; + } + }, + _doProcessBlock: function(words, offset) { + this._mode.processBlock(words, offset); + }, + _doFinalize: function() { + var finalProcessedBlocks; + var padding = this.cfg.padding; + if (this._xformMode == this._ENC_XFORM_MODE) { + padding.pad(this._data, this.blockSize); + finalProcessedBlocks = this._process(true); + } else { + finalProcessedBlocks = this._process(true); + padding.unpad(finalProcessedBlocks); + } + return finalProcessedBlocks; + }, + blockSize: 128 / 32 + }); + var CipherParams = C_lib.CipherParams = Base.extend({ + /** + * Initializes a newly created cipher params object. + * + * @param {Object} cipherParams An object with any of the possible cipher parameters. + * + * @example + * + * var cipherParams = CryptoJS.lib.CipherParams.create({ + * ciphertext: ciphertextWordArray, + * key: keyWordArray, + * iv: ivWordArray, + * salt: saltWordArray, + * algorithm: CryptoJS.algo.AES, + * mode: CryptoJS.mode.CBC, + * padding: CryptoJS.pad.PKCS7, + * blockSize: 4, + * formatter: CryptoJS.format.OpenSSL + * }); + */ + init: function(cipherParams) { + this.mixIn(cipherParams); + }, + /** + * Converts this cipher params object to a string. + * + * @param {Format} formatter (Optional) The formatting strategy to use. + * + * @return {string} The stringified cipher params. + * + * @throws Error If neither the formatter nor the default formatter is set. + * + * @example + * + * var string = cipherParams + ''; + * var string = cipherParams.toString(); + * var string = cipherParams.toString(CryptoJS.format.OpenSSL); + */ + toString: function(formatter) { + return (formatter || this.formatter).stringify(this); + } + }); + var C_format = C2.format = {}; + var OpenSSLFormatter = C_format.OpenSSL = { + /** + * Converts a cipher params object to an OpenSSL-compatible string. + * + * @param {CipherParams} cipherParams The cipher params object. + * + * @return {string} The OpenSSL-compatible string. + * + * @static + * + * @example + * + * var openSSLString = CryptoJS.format.OpenSSL.stringify(cipherParams); + */ + stringify: function(cipherParams) { + var wordArray; + var ciphertext = cipherParams.ciphertext; + var salt = cipherParams.salt; + if (salt) { + wordArray = WordArray.create([1398893684, 1701076831]).concat(salt).concat(ciphertext); + } else { + wordArray = ciphertext; + } + return wordArray.toString(Base64); + }, + /** + * Converts an OpenSSL-compatible string to a cipher params object. + * + * @param {string} openSSLStr The OpenSSL-compatible string. + * + * @return {CipherParams} The cipher params object. + * + * @static + * + * @example + * + * var cipherParams = CryptoJS.format.OpenSSL.parse(openSSLString); + */ + parse: function(openSSLStr) { + var salt; + var ciphertext = Base64.parse(openSSLStr); + var ciphertextWords = ciphertext.words; + if (ciphertextWords[0] == 1398893684 && ciphertextWords[1] == 1701076831) { + salt = WordArray.create(ciphertextWords.slice(2, 4)); + ciphertextWords.splice(0, 4); + ciphertext.sigBytes -= 16; + } + return CipherParams.create({ ciphertext, salt }); + } + }; + var SerializableCipher = C_lib.SerializableCipher = Base.extend({ + /** + * Configuration options. + * + * @property {Formatter} format The formatting strategy to convert cipher param objects to and from a string. Default: OpenSSL + */ + cfg: Base.extend({ + format: OpenSSLFormatter + }), + /** + * Encrypts a message. + * + * @param {Cipher} cipher The cipher algorithm to use. + * @param {WordArray|string} message The message to encrypt. + * @param {WordArray} key The key. + * @param {Object} cfg (Optional) The configuration options to use for this operation. + * + * @return {CipherParams} A cipher params object. + * + * @static + * + * @example + * + * var ciphertextParams = CryptoJS.lib.SerializableCipher.encrypt(CryptoJS.algo.AES, message, key); + * var ciphertextParams = CryptoJS.lib.SerializableCipher.encrypt(CryptoJS.algo.AES, message, key, { iv: iv }); + * var ciphertextParams = CryptoJS.lib.SerializableCipher.encrypt(CryptoJS.algo.AES, message, key, { iv: iv, format: CryptoJS.format.OpenSSL }); + */ + encrypt: function(cipher, message, key, cfg) { + cfg = this.cfg.extend(cfg); + var encryptor = cipher.createEncryptor(key, cfg); + var ciphertext = encryptor.finalize(message); + var cipherCfg = encryptor.cfg; + return CipherParams.create({ + ciphertext, + key, + iv: cipherCfg.iv, + algorithm: cipher, + mode: cipherCfg.mode, + padding: cipherCfg.padding, + blockSize: cipher.blockSize, + formatter: cfg.format + }); + }, + /** + * Decrypts serialized ciphertext. + * + * @param {Cipher} cipher The cipher algorithm to use. + * @param {CipherParams|string} ciphertext The ciphertext to decrypt. + * @param {WordArray} key The key. + * @param {Object} cfg (Optional) The configuration options to use for this operation. + * + * @return {WordArray} The plaintext. + * + * @static + * + * @example + * + * var plaintext = CryptoJS.lib.SerializableCipher.decrypt(CryptoJS.algo.AES, formattedCiphertext, key, { iv: iv, format: CryptoJS.format.OpenSSL }); + * var plaintext = CryptoJS.lib.SerializableCipher.decrypt(CryptoJS.algo.AES, ciphertextParams, key, { iv: iv, format: CryptoJS.format.OpenSSL }); + */ + decrypt: function(cipher, ciphertext, key, cfg) { + cfg = this.cfg.extend(cfg); + ciphertext = this._parse(ciphertext, cfg.format); + var plaintext = cipher.createDecryptor(key, cfg).finalize(ciphertext.ciphertext); + return plaintext; + }, + /** + * Converts serialized ciphertext to CipherParams, + * else assumed CipherParams already and returns ciphertext unchanged. + * + * @param {CipherParams|string} ciphertext The ciphertext. + * @param {Formatter} format The formatting strategy to use to parse serialized ciphertext. + * + * @return {CipherParams} The unserialized ciphertext. + * + * @static + * + * @example + * + * var ciphertextParams = CryptoJS.lib.SerializableCipher._parse(ciphertextStringOrParams, format); + */ + _parse: function(ciphertext, format) { + if (typeof ciphertext == "string") { + return format.parse(ciphertext, this); + } else { + return ciphertext; + } + } + }); + var C_kdf = C2.kdf = {}; + var OpenSSLKdf = C_kdf.OpenSSL = { + /** + * Derives a key and IV from a password. + * + * @param {string} password The password to derive from. + * @param {number} keySize The size in words of the key to generate. + * @param {number} ivSize The size in words of the IV to generate. + * @param {WordArray|string} salt (Optional) A 64-bit salt to use. If omitted, a salt will be generated randomly. + * + * @return {CipherParams} A cipher params object with the key, IV, and salt. + * + * @static + * + * @example + * + * var derivedParams = CryptoJS.kdf.OpenSSL.execute('Password', 256/32, 128/32); + * var derivedParams = CryptoJS.kdf.OpenSSL.execute('Password', 256/32, 128/32, 'saltsalt'); + */ + execute: function(password, keySize, ivSize, salt, hasher) { + if (!salt) { + salt = WordArray.random(64 / 8); + } + if (!hasher) { + var key = EvpKDF.create({ keySize: keySize + ivSize }).compute(password, salt); + } else { + var key = EvpKDF.create({ keySize: keySize + ivSize, hasher }).compute(password, salt); + } + var iv = WordArray.create(key.words.slice(keySize), ivSize * 4); + key.sigBytes = keySize * 4; + return CipherParams.create({ key, iv, salt }); + } + }; + var PasswordBasedCipher = C_lib.PasswordBasedCipher = SerializableCipher.extend({ + /** + * Configuration options. + * + * @property {KDF} kdf The key derivation function to use to generate a key and IV from a password. Default: OpenSSL + */ + cfg: SerializableCipher.cfg.extend({ + kdf: OpenSSLKdf + }), + /** + * Encrypts a message using a password. + * + * @param {Cipher} cipher The cipher algorithm to use. + * @param {WordArray|string} message The message to encrypt. + * @param {string} password The password. + * @param {Object} cfg (Optional) The configuration options to use for this operation. + * + * @return {CipherParams} A cipher params object. + * + * @static + * + * @example + * + * var ciphertextParams = CryptoJS.lib.PasswordBasedCipher.encrypt(CryptoJS.algo.AES, message, 'password'); + * var ciphertextParams = CryptoJS.lib.PasswordBasedCipher.encrypt(CryptoJS.algo.AES, message, 'password', { format: CryptoJS.format.OpenSSL }); + */ + encrypt: function(cipher, message, password, cfg) { + cfg = this.cfg.extend(cfg); + var derivedParams = cfg.kdf.execute(password, cipher.keySize, cipher.ivSize, cfg.salt, cfg.hasher); + cfg.iv = derivedParams.iv; + var ciphertext = SerializableCipher.encrypt.call(this, cipher, message, derivedParams.key, cfg); + ciphertext.mixIn(derivedParams); + return ciphertext; + }, + /** + * Decrypts serialized ciphertext using a password. + * + * @param {Cipher} cipher The cipher algorithm to use. + * @param {CipherParams|string} ciphertext The ciphertext to decrypt. + * @param {string} password The password. + * @param {Object} cfg (Optional) The configuration options to use for this operation. + * + * @return {WordArray} The plaintext. + * + * @static + * + * @example + * + * var plaintext = CryptoJS.lib.PasswordBasedCipher.decrypt(CryptoJS.algo.AES, formattedCiphertext, 'password', { format: CryptoJS.format.OpenSSL }); + * var plaintext = CryptoJS.lib.PasswordBasedCipher.decrypt(CryptoJS.algo.AES, ciphertextParams, 'password', { format: CryptoJS.format.OpenSSL }); + */ + decrypt: function(cipher, ciphertext, password, cfg) { + cfg = this.cfg.extend(cfg); + ciphertext = this._parse(ciphertext, cfg.format); + var derivedParams = cfg.kdf.execute(password, cipher.keySize, cipher.ivSize, ciphertext.salt, cfg.hasher); + cfg.iv = derivedParams.iv; + var plaintext = SerializableCipher.decrypt.call(this, cipher, ciphertext, derivedParams.key, cfg); + return plaintext; + } + }); + })(); + }); + } +}); + +// node_modules/crypto-js/mode-cfb.js +var require_mode_cfb = __commonJS({ + "node_modules/crypto-js/mode-cfb.js"(exports, module) { + (function(root, factory, undef) { + if (typeof exports === "object") { + module.exports = exports = factory(require_core(), require_cipher_core()); + } else if (typeof define === "function" && define.amd) { + define(["./core", "./cipher-core"], factory); + } else { + factory(root.CryptoJS); + } + })(exports, function(CryptoJS2) { + CryptoJS2.mode.CFB = (function() { + var CFB = CryptoJS2.lib.BlockCipherMode.extend(); + CFB.Encryptor = CFB.extend({ + processBlock: function(words, offset) { + var cipher = this._cipher; + var blockSize = cipher.blockSize; + generateKeystreamAndEncrypt.call(this, words, offset, blockSize, cipher); + this._prevBlock = words.slice(offset, offset + blockSize); + } + }); + CFB.Decryptor = CFB.extend({ + processBlock: function(words, offset) { + var cipher = this._cipher; + var blockSize = cipher.blockSize; + var thisBlock = words.slice(offset, offset + blockSize); + generateKeystreamAndEncrypt.call(this, words, offset, blockSize, cipher); + this._prevBlock = thisBlock; + } + }); + function generateKeystreamAndEncrypt(words, offset, blockSize, cipher) { + var keystream; + var iv = this._iv; + if (iv) { + keystream = iv.slice(0); + this._iv = void 0; + } else { + keystream = this._prevBlock; + } + cipher.encryptBlock(keystream, 0); + for (var i = 0; i < blockSize; i++) { + words[offset + i] ^= keystream[i]; + } + } + return CFB; + })(); + return CryptoJS2.mode.CFB; + }); + } +}); + +// node_modules/crypto-js/mode-ctr.js +var require_mode_ctr = __commonJS({ + "node_modules/crypto-js/mode-ctr.js"(exports, module) { + (function(root, factory, undef) { + if (typeof exports === "object") { + module.exports = exports = factory(require_core(), require_cipher_core()); + } else if (typeof define === "function" && define.amd) { + define(["./core", "./cipher-core"], factory); + } else { + factory(root.CryptoJS); + } + })(exports, function(CryptoJS2) { + CryptoJS2.mode.CTR = (function() { + var CTR = CryptoJS2.lib.BlockCipherMode.extend(); + var Encryptor = CTR.Encryptor = CTR.extend({ + processBlock: function(words, offset) { + var cipher = this._cipher; + var blockSize = cipher.blockSize; + var iv = this._iv; + var counter = this._counter; + if (iv) { + counter = this._counter = iv.slice(0); + this._iv = void 0; + } + var keystream = counter.slice(0); + cipher.encryptBlock(keystream, 0); + counter[blockSize - 1] = counter[blockSize - 1] + 1 | 0; + for (var i = 0; i < blockSize; i++) { + words[offset + i] ^= keystream[i]; + } + } + }); + CTR.Decryptor = Encryptor; + return CTR; + })(); + return CryptoJS2.mode.CTR; + }); + } +}); + +// node_modules/crypto-js/mode-ctr-gladman.js +var require_mode_ctr_gladman = __commonJS({ + "node_modules/crypto-js/mode-ctr-gladman.js"(exports, module) { + (function(root, factory, undef) { + if (typeof exports === "object") { + module.exports = exports = factory(require_core(), require_cipher_core()); + } else if (typeof define === "function" && define.amd) { + define(["./core", "./cipher-core"], factory); + } else { + factory(root.CryptoJS); + } + })(exports, function(CryptoJS2) { + CryptoJS2.mode.CTRGladman = (function() { + var CTRGladman = CryptoJS2.lib.BlockCipherMode.extend(); + function incWord(word) { + if ((word >> 24 & 255) === 255) { + var b1 = word >> 16 & 255; + var b2 = word >> 8 & 255; + var b3 = word & 255; + if (b1 === 255) { + b1 = 0; + if (b2 === 255) { + b2 = 0; + if (b3 === 255) { + b3 = 0; + } else { + ++b3; + } + } else { + ++b2; + } + } else { + ++b1; + } + word = 0; + word += b1 << 16; + word += b2 << 8; + word += b3; + } else { + word += 1 << 24; + } + return word; + } + function incCounter(counter) { + if ((counter[0] = incWord(counter[0])) === 0) { + counter[1] = incWord(counter[1]); + } + return counter; + } + var Encryptor = CTRGladman.Encryptor = CTRGladman.extend({ + processBlock: function(words, offset) { + var cipher = this._cipher; + var blockSize = cipher.blockSize; + var iv = this._iv; + var counter = this._counter; + if (iv) { + counter = this._counter = iv.slice(0); + this._iv = void 0; + } + incCounter(counter); + var keystream = counter.slice(0); + cipher.encryptBlock(keystream, 0); + for (var i = 0; i < blockSize; i++) { + words[offset + i] ^= keystream[i]; + } + } + }); + CTRGladman.Decryptor = Encryptor; + return CTRGladman; + })(); + return CryptoJS2.mode.CTRGladman; + }); + } +}); + +// node_modules/crypto-js/mode-ofb.js +var require_mode_ofb = __commonJS({ + "node_modules/crypto-js/mode-ofb.js"(exports, module) { + (function(root, factory, undef) { + if (typeof exports === "object") { + module.exports = exports = factory(require_core(), require_cipher_core()); + } else if (typeof define === "function" && define.amd) { + define(["./core", "./cipher-core"], factory); + } else { + factory(root.CryptoJS); + } + })(exports, function(CryptoJS2) { + CryptoJS2.mode.OFB = (function() { + var OFB = CryptoJS2.lib.BlockCipherMode.extend(); + var Encryptor = OFB.Encryptor = OFB.extend({ + processBlock: function(words, offset) { + var cipher = this._cipher; + var blockSize = cipher.blockSize; + var iv = this._iv; + var keystream = this._keystream; + if (iv) { + keystream = this._keystream = iv.slice(0); + this._iv = void 0; + } + cipher.encryptBlock(keystream, 0); + for (var i = 0; i < blockSize; i++) { + words[offset + i] ^= keystream[i]; + } + } + }); + OFB.Decryptor = Encryptor; + return OFB; + })(); + return CryptoJS2.mode.OFB; + }); + } +}); + +// node_modules/crypto-js/mode-ecb.js +var require_mode_ecb = __commonJS({ + "node_modules/crypto-js/mode-ecb.js"(exports, module) { + (function(root, factory, undef) { + if (typeof exports === "object") { + module.exports = exports = factory(require_core(), require_cipher_core()); + } else if (typeof define === "function" && define.amd) { + define(["./core", "./cipher-core"], factory); + } else { + factory(root.CryptoJS); + } + })(exports, function(CryptoJS2) { + CryptoJS2.mode.ECB = (function() { + var ECB = CryptoJS2.lib.BlockCipherMode.extend(); + ECB.Encryptor = ECB.extend({ + processBlock: function(words, offset) { + this._cipher.encryptBlock(words, offset); + } + }); + ECB.Decryptor = ECB.extend({ + processBlock: function(words, offset) { + this._cipher.decryptBlock(words, offset); + } + }); + return ECB; + })(); + return CryptoJS2.mode.ECB; + }); + } +}); + +// node_modules/crypto-js/pad-ansix923.js +var require_pad_ansix923 = __commonJS({ + "node_modules/crypto-js/pad-ansix923.js"(exports, module) { + (function(root, factory, undef) { + if (typeof exports === "object") { + module.exports = exports = factory(require_core(), require_cipher_core()); + } else if (typeof define === "function" && define.amd) { + define(["./core", "./cipher-core"], factory); + } else { + factory(root.CryptoJS); + } + })(exports, function(CryptoJS2) { + CryptoJS2.pad.AnsiX923 = { + pad: function(data, blockSize) { + var dataSigBytes = data.sigBytes; + var blockSizeBytes = blockSize * 4; + var nPaddingBytes = blockSizeBytes - dataSigBytes % blockSizeBytes; + var lastBytePos = dataSigBytes + nPaddingBytes - 1; + data.clamp(); + data.words[lastBytePos >>> 2] |= nPaddingBytes << 24 - lastBytePos % 4 * 8; + data.sigBytes += nPaddingBytes; + }, + unpad: function(data) { + var nPaddingBytes = data.words[data.sigBytes - 1 >>> 2] & 255; + data.sigBytes -= nPaddingBytes; + } + }; + return CryptoJS2.pad.Ansix923; + }); + } +}); + +// node_modules/crypto-js/pad-iso10126.js +var require_pad_iso10126 = __commonJS({ + "node_modules/crypto-js/pad-iso10126.js"(exports, module) { + (function(root, factory, undef) { + if (typeof exports === "object") { + module.exports = exports = factory(require_core(), require_cipher_core()); + } else if (typeof define === "function" && define.amd) { + define(["./core", "./cipher-core"], factory); + } else { + factory(root.CryptoJS); + } + })(exports, function(CryptoJS2) { + CryptoJS2.pad.Iso10126 = { + pad: function(data, blockSize) { + var blockSizeBytes = blockSize * 4; + var nPaddingBytes = blockSizeBytes - data.sigBytes % blockSizeBytes; + data.concat(CryptoJS2.lib.WordArray.random(nPaddingBytes - 1)).concat(CryptoJS2.lib.WordArray.create([nPaddingBytes << 24], 1)); + }, + unpad: function(data) { + var nPaddingBytes = data.words[data.sigBytes - 1 >>> 2] & 255; + data.sigBytes -= nPaddingBytes; + } + }; + return CryptoJS2.pad.Iso10126; + }); + } +}); + +// node_modules/crypto-js/pad-iso97971.js +var require_pad_iso97971 = __commonJS({ + "node_modules/crypto-js/pad-iso97971.js"(exports, module) { + (function(root, factory, undef) { + if (typeof exports === "object") { + module.exports = exports = factory(require_core(), require_cipher_core()); + } else if (typeof define === "function" && define.amd) { + define(["./core", "./cipher-core"], factory); + } else { + factory(root.CryptoJS); + } + })(exports, function(CryptoJS2) { + CryptoJS2.pad.Iso97971 = { + pad: function(data, blockSize) { + data.concat(CryptoJS2.lib.WordArray.create([2147483648], 1)); + CryptoJS2.pad.ZeroPadding.pad(data, blockSize); + }, + unpad: function(data) { + CryptoJS2.pad.ZeroPadding.unpad(data); + data.sigBytes--; + } + }; + return CryptoJS2.pad.Iso97971; + }); + } +}); + +// node_modules/crypto-js/pad-zeropadding.js +var require_pad_zeropadding = __commonJS({ + "node_modules/crypto-js/pad-zeropadding.js"(exports, module) { + (function(root, factory, undef) { + if (typeof exports === "object") { + module.exports = exports = factory(require_core(), require_cipher_core()); + } else if (typeof define === "function" && define.amd) { + define(["./core", "./cipher-core"], factory); + } else { + factory(root.CryptoJS); + } + })(exports, function(CryptoJS2) { + CryptoJS2.pad.ZeroPadding = { + pad: function(data, blockSize) { + var blockSizeBytes = blockSize * 4; + data.clamp(); + data.sigBytes += blockSizeBytes - (data.sigBytes % blockSizeBytes || blockSizeBytes); + }, + unpad: function(data) { + var dataWords = data.words; + var i = data.sigBytes - 1; + for (var i = data.sigBytes - 1; i >= 0; i--) { + if (dataWords[i >>> 2] >>> 24 - i % 4 * 8 & 255) { + data.sigBytes = i + 1; + break; + } + } + } + }; + return CryptoJS2.pad.ZeroPadding; + }); + } +}); + +// node_modules/crypto-js/pad-nopadding.js +var require_pad_nopadding = __commonJS({ + "node_modules/crypto-js/pad-nopadding.js"(exports, module) { + (function(root, factory, undef) { + if (typeof exports === "object") { + module.exports = exports = factory(require_core(), require_cipher_core()); + } else if (typeof define === "function" && define.amd) { + define(["./core", "./cipher-core"], factory); + } else { + factory(root.CryptoJS); + } + })(exports, function(CryptoJS2) { + CryptoJS2.pad.NoPadding = { + pad: function() { + }, + unpad: function() { + } + }; + return CryptoJS2.pad.NoPadding; + }); + } +}); + +// node_modules/crypto-js/format-hex.js +var require_format_hex = __commonJS({ + "node_modules/crypto-js/format-hex.js"(exports, module) { + (function(root, factory, undef) { + if (typeof exports === "object") { + module.exports = exports = factory(require_core(), require_cipher_core()); + } else if (typeof define === "function" && define.amd) { + define(["./core", "./cipher-core"], factory); + } else { + factory(root.CryptoJS); + } + })(exports, function(CryptoJS2) { + (function(undefined2) { + var C2 = CryptoJS2; + var C_lib = C2.lib; + var CipherParams = C_lib.CipherParams; + var C_enc = C2.enc; + var Hex = C_enc.Hex; + var C_format = C2.format; + var HexFormatter = C_format.Hex = { + /** + * Converts the ciphertext of a cipher params object to a hexadecimally encoded string. + * + * @param {CipherParams} cipherParams The cipher params object. + * + * @return {string} The hexadecimally encoded string. + * + * @static + * + * @example + * + * var hexString = CryptoJS.format.Hex.stringify(cipherParams); + */ + stringify: function(cipherParams) { + return cipherParams.ciphertext.toString(Hex); + }, + /** + * Converts a hexadecimally encoded ciphertext string to a cipher params object. + * + * @param {string} input The hexadecimally encoded string. + * + * @return {CipherParams} The cipher params object. + * + * @static + * + * @example + * + * var cipherParams = CryptoJS.format.Hex.parse(hexString); + */ + parse: function(input) { + var ciphertext = Hex.parse(input); + return CipherParams.create({ ciphertext }); + } + }; + })(); + return CryptoJS2.format.Hex; + }); + } +}); + +// node_modules/crypto-js/aes.js +var require_aes = __commonJS({ + "node_modules/crypto-js/aes.js"(exports, module) { + (function(root, factory, undef) { + if (typeof exports === "object") { + module.exports = exports = factory(require_core(), require_enc_base64(), require_md5(), require_evpkdf(), require_cipher_core()); + } else if (typeof define === "function" && define.amd) { + define(["./core", "./enc-base64", "./md5", "./evpkdf", "./cipher-core"], factory); + } else { + factory(root.CryptoJS); + } + })(exports, function(CryptoJS2) { + (function() { + var C2 = CryptoJS2; + var C_lib = C2.lib; + var BlockCipher = C_lib.BlockCipher; + var C_algo = C2.algo; + var SBOX = []; + var INV_SBOX = []; + var SUB_MIX_0 = []; + var SUB_MIX_1 = []; + var SUB_MIX_2 = []; + var SUB_MIX_3 = []; + var INV_SUB_MIX_0 = []; + var INV_SUB_MIX_1 = []; + var INV_SUB_MIX_2 = []; + var INV_SUB_MIX_3 = []; + (function() { + var d = []; + for (var i = 0; i < 256; i++) { + if (i < 128) { + d[i] = i << 1; + } else { + d[i] = i << 1 ^ 283; + } + } + var x = 0; + var xi = 0; + for (var i = 0; i < 256; i++) { + var sx = xi ^ xi << 1 ^ xi << 2 ^ xi << 3 ^ xi << 4; + sx = sx >>> 8 ^ sx & 255 ^ 99; + SBOX[x] = sx; + INV_SBOX[sx] = x; + var x2 = d[x]; + var x4 = d[x2]; + var x8 = d[x4]; + var t = d[sx] * 257 ^ sx * 16843008; + SUB_MIX_0[x] = t << 24 | t >>> 8; + SUB_MIX_1[x] = t << 16 | t >>> 16; + SUB_MIX_2[x] = t << 8 | t >>> 24; + SUB_MIX_3[x] = t; + var t = x8 * 16843009 ^ x4 * 65537 ^ x2 * 257 ^ x * 16843008; + INV_SUB_MIX_0[sx] = t << 24 | t >>> 8; + INV_SUB_MIX_1[sx] = t << 16 | t >>> 16; + INV_SUB_MIX_2[sx] = t << 8 | t >>> 24; + INV_SUB_MIX_3[sx] = t; + if (!x) { + x = xi = 1; + } else { + x = x2 ^ d[d[d[x8 ^ x2]]]; + xi ^= d[d[xi]]; + } + } + })(); + var RCON = [0, 1, 2, 4, 8, 16, 32, 64, 128, 27, 54]; + var AES2 = C_algo.AES = BlockCipher.extend({ + _doReset: function() { + var t; + if (this._nRounds && this._keyPriorReset === this._key) { + return; + } + var key = this._keyPriorReset = this._key; + var keyWords = key.words; + var keySize = key.sigBytes / 4; + var nRounds = this._nRounds = keySize + 6; + var ksRows = (nRounds + 1) * 4; + var keySchedule = this._keySchedule = []; + for (var ksRow = 0; ksRow < ksRows; ksRow++) { + if (ksRow < keySize) { + keySchedule[ksRow] = keyWords[ksRow]; + } else { + t = keySchedule[ksRow - 1]; + if (!(ksRow % keySize)) { + t = t << 8 | t >>> 24; + t = SBOX[t >>> 24] << 24 | SBOX[t >>> 16 & 255] << 16 | SBOX[t >>> 8 & 255] << 8 | SBOX[t & 255]; + t ^= RCON[ksRow / keySize | 0] << 24; + } else if (keySize > 6 && ksRow % keySize == 4) { + t = SBOX[t >>> 24] << 24 | SBOX[t >>> 16 & 255] << 16 | SBOX[t >>> 8 & 255] << 8 | SBOX[t & 255]; + } + keySchedule[ksRow] = keySchedule[ksRow - keySize] ^ t; + } + } + var invKeySchedule = this._invKeySchedule = []; + for (var invKsRow = 0; invKsRow < ksRows; invKsRow++) { + var ksRow = ksRows - invKsRow; + if (invKsRow % 4) { + var t = keySchedule[ksRow]; + } else { + var t = keySchedule[ksRow - 4]; + } + if (invKsRow < 4 || ksRow <= 4) { + invKeySchedule[invKsRow] = t; + } else { + invKeySchedule[invKsRow] = INV_SUB_MIX_0[SBOX[t >>> 24]] ^ INV_SUB_MIX_1[SBOX[t >>> 16 & 255]] ^ INV_SUB_MIX_2[SBOX[t >>> 8 & 255]] ^ INV_SUB_MIX_3[SBOX[t & 255]]; + } + } + }, + encryptBlock: function(M2, offset) { + this._doCryptBlock(M2, offset, this._keySchedule, SUB_MIX_0, SUB_MIX_1, SUB_MIX_2, SUB_MIX_3, SBOX); + }, + decryptBlock: function(M2, offset) { + var t = M2[offset + 1]; + M2[offset + 1] = M2[offset + 3]; + M2[offset + 3] = t; + this._doCryptBlock(M2, offset, this._invKeySchedule, INV_SUB_MIX_0, INV_SUB_MIX_1, INV_SUB_MIX_2, INV_SUB_MIX_3, INV_SBOX); + var t = M2[offset + 1]; + M2[offset + 1] = M2[offset + 3]; + M2[offset + 3] = t; + }, + _doCryptBlock: function(M2, offset, keySchedule, SUB_MIX_02, SUB_MIX_12, SUB_MIX_22, SUB_MIX_32, SBOX2) { + var nRounds = this._nRounds; + var s0 = M2[offset] ^ keySchedule[0]; + var s1 = M2[offset + 1] ^ keySchedule[1]; + var s2 = M2[offset + 2] ^ keySchedule[2]; + var s3 = M2[offset + 3] ^ keySchedule[3]; + var ksRow = 4; + for (var round = 1; round < nRounds; round++) { + var t0 = SUB_MIX_02[s0 >>> 24] ^ SUB_MIX_12[s1 >>> 16 & 255] ^ SUB_MIX_22[s2 >>> 8 & 255] ^ SUB_MIX_32[s3 & 255] ^ keySchedule[ksRow++]; + var t1 = SUB_MIX_02[s1 >>> 24] ^ SUB_MIX_12[s2 >>> 16 & 255] ^ SUB_MIX_22[s3 >>> 8 & 255] ^ SUB_MIX_32[s0 & 255] ^ keySchedule[ksRow++]; + var t2 = SUB_MIX_02[s2 >>> 24] ^ SUB_MIX_12[s3 >>> 16 & 255] ^ SUB_MIX_22[s0 >>> 8 & 255] ^ SUB_MIX_32[s1 & 255] ^ keySchedule[ksRow++]; + var t3 = SUB_MIX_02[s3 >>> 24] ^ SUB_MIX_12[s0 >>> 16 & 255] ^ SUB_MIX_22[s1 >>> 8 & 255] ^ SUB_MIX_32[s2 & 255] ^ keySchedule[ksRow++]; + s0 = t0; + s1 = t1; + s2 = t2; + s3 = t3; + } + var t0 = (SBOX2[s0 >>> 24] << 24 | SBOX2[s1 >>> 16 & 255] << 16 | SBOX2[s2 >>> 8 & 255] << 8 | SBOX2[s3 & 255]) ^ keySchedule[ksRow++]; + var t1 = (SBOX2[s1 >>> 24] << 24 | SBOX2[s2 >>> 16 & 255] << 16 | SBOX2[s3 >>> 8 & 255] << 8 | SBOX2[s0 & 255]) ^ keySchedule[ksRow++]; + var t2 = (SBOX2[s2 >>> 24] << 24 | SBOX2[s3 >>> 16 & 255] << 16 | SBOX2[s0 >>> 8 & 255] << 8 | SBOX2[s1 & 255]) ^ keySchedule[ksRow++]; + var t3 = (SBOX2[s3 >>> 24] << 24 | SBOX2[s0 >>> 16 & 255] << 16 | SBOX2[s1 >>> 8 & 255] << 8 | SBOX2[s2 & 255]) ^ keySchedule[ksRow++]; + M2[offset] = t0; + M2[offset + 1] = t1; + M2[offset + 2] = t2; + M2[offset + 3] = t3; + }, + keySize: 256 / 32 + }); + C2.AES = BlockCipher._createHelper(AES2); + })(); + return CryptoJS2.AES; + }); + } +}); + +// node_modules/crypto-js/tripledes.js +var require_tripledes = __commonJS({ + "node_modules/crypto-js/tripledes.js"(exports, module) { + (function(root, factory, undef) { + if (typeof exports === "object") { + module.exports = exports = factory(require_core(), require_enc_base64(), require_md5(), require_evpkdf(), require_cipher_core()); + } else if (typeof define === "function" && define.amd) { + define(["./core", "./enc-base64", "./md5", "./evpkdf", "./cipher-core"], factory); + } else { + factory(root.CryptoJS); + } + })(exports, function(CryptoJS2) { + (function() { + var C2 = CryptoJS2; + var C_lib = C2.lib; + var WordArray = C_lib.WordArray; + var BlockCipher = C_lib.BlockCipher; + var C_algo = C2.algo; + var PC1 = [ + 57, + 49, + 41, + 33, + 25, + 17, + 9, + 1, + 58, + 50, + 42, + 34, + 26, + 18, + 10, + 2, + 59, + 51, + 43, + 35, + 27, + 19, + 11, + 3, + 60, + 52, + 44, + 36, + 63, + 55, + 47, + 39, + 31, + 23, + 15, + 7, + 62, + 54, + 46, + 38, + 30, + 22, + 14, + 6, + 61, + 53, + 45, + 37, + 29, + 21, + 13, + 5, + 28, + 20, + 12, + 4 + ]; + var PC2 = [ + 14, + 17, + 11, + 24, + 1, + 5, + 3, + 28, + 15, + 6, + 21, + 10, + 23, + 19, + 12, + 4, + 26, + 8, + 16, + 7, + 27, + 20, + 13, + 2, + 41, + 52, + 31, + 37, + 47, + 55, + 30, + 40, + 51, + 45, + 33, + 48, + 44, + 49, + 39, + 56, + 34, + 53, + 46, + 42, + 50, + 36, + 29, + 32 + ]; + var BIT_SHIFTS = [1, 2, 4, 6, 8, 10, 12, 14, 15, 17, 19, 21, 23, 25, 27, 28]; + var SBOX_P = [ + { + 0: 8421888, + 268435456: 32768, + 536870912: 8421378, + 805306368: 2, + 1073741824: 512, + 1342177280: 8421890, + 1610612736: 8389122, + 1879048192: 8388608, + 2147483648: 514, + 2415919104: 8389120, + 2684354560: 33280, + 2952790016: 8421376, + 3221225472: 32770, + 3489660928: 8388610, + 3758096384: 0, + 4026531840: 33282, + 134217728: 0, + 402653184: 8421890, + 671088640: 33282, + 939524096: 32768, + 1207959552: 8421888, + 1476395008: 512, + 1744830464: 8421378, + 2013265920: 2, + 2281701376: 8389120, + 2550136832: 33280, + 2818572288: 8421376, + 3087007744: 8389122, + 3355443200: 8388610, + 3623878656: 32770, + 3892314112: 514, + 4160749568: 8388608, + 1: 32768, + 268435457: 2, + 536870913: 8421888, + 805306369: 8388608, + 1073741825: 8421378, + 1342177281: 33280, + 1610612737: 512, + 1879048193: 8389122, + 2147483649: 8421890, + 2415919105: 8421376, + 2684354561: 8388610, + 2952790017: 33282, + 3221225473: 514, + 3489660929: 8389120, + 3758096385: 32770, + 4026531841: 0, + 134217729: 8421890, + 402653185: 8421376, + 671088641: 8388608, + 939524097: 512, + 1207959553: 32768, + 1476395009: 8388610, + 1744830465: 2, + 2013265921: 33282, + 2281701377: 32770, + 2550136833: 8389122, + 2818572289: 514, + 3087007745: 8421888, + 3355443201: 8389120, + 3623878657: 0, + 3892314113: 33280, + 4160749569: 8421378 + }, + { + 0: 1074282512, + 16777216: 16384, + 33554432: 524288, + 50331648: 1074266128, + 67108864: 1073741840, + 83886080: 1074282496, + 100663296: 1073758208, + 117440512: 16, + 134217728: 540672, + 150994944: 1073758224, + 167772160: 1073741824, + 184549376: 540688, + 201326592: 524304, + 218103808: 0, + 234881024: 16400, + 251658240: 1074266112, + 8388608: 1073758208, + 25165824: 540688, + 41943040: 16, + 58720256: 1073758224, + 75497472: 1074282512, + 92274688: 1073741824, + 109051904: 524288, + 125829120: 1074266128, + 142606336: 524304, + 159383552: 0, + 176160768: 16384, + 192937984: 1074266112, + 209715200: 1073741840, + 226492416: 540672, + 243269632: 1074282496, + 260046848: 16400, + 268435456: 0, + 285212672: 1074266128, + 301989888: 1073758224, + 318767104: 1074282496, + 335544320: 1074266112, + 352321536: 16, + 369098752: 540688, + 385875968: 16384, + 402653184: 16400, + 419430400: 524288, + 436207616: 524304, + 452984832: 1073741840, + 469762048: 540672, + 486539264: 1073758208, + 503316480: 1073741824, + 520093696: 1074282512, + 276824064: 540688, + 293601280: 524288, + 310378496: 1074266112, + 327155712: 16384, + 343932928: 1073758208, + 360710144: 1074282512, + 377487360: 16, + 394264576: 1073741824, + 411041792: 1074282496, + 427819008: 1073741840, + 444596224: 1073758224, + 461373440: 524304, + 478150656: 0, + 494927872: 16400, + 511705088: 1074266128, + 528482304: 540672 + }, + { + 0: 260, + 1048576: 0, + 2097152: 67109120, + 3145728: 65796, + 4194304: 65540, + 5242880: 67108868, + 6291456: 67174660, + 7340032: 67174400, + 8388608: 67108864, + 9437184: 67174656, + 10485760: 65792, + 11534336: 67174404, + 12582912: 67109124, + 13631488: 65536, + 14680064: 4, + 15728640: 256, + 524288: 67174656, + 1572864: 67174404, + 2621440: 0, + 3670016: 67109120, + 4718592: 67108868, + 5767168: 65536, + 6815744: 65540, + 7864320: 260, + 8912896: 4, + 9961472: 256, + 11010048: 67174400, + 12058624: 65796, + 13107200: 65792, + 14155776: 67109124, + 15204352: 67174660, + 16252928: 67108864, + 16777216: 67174656, + 17825792: 65540, + 18874368: 65536, + 19922944: 67109120, + 20971520: 256, + 22020096: 67174660, + 23068672: 67108868, + 24117248: 0, + 25165824: 67109124, + 26214400: 67108864, + 27262976: 4, + 28311552: 65792, + 29360128: 67174400, + 30408704: 260, + 31457280: 65796, + 32505856: 67174404, + 17301504: 67108864, + 18350080: 260, + 19398656: 67174656, + 20447232: 0, + 21495808: 65540, + 22544384: 67109120, + 23592960: 256, + 24641536: 67174404, + 25690112: 65536, + 26738688: 67174660, + 27787264: 65796, + 28835840: 67108868, + 29884416: 67109124, + 30932992: 67174400, + 31981568: 4, + 33030144: 65792 + }, + { + 0: 2151682048, + 65536: 2147487808, + 131072: 4198464, + 196608: 2151677952, + 262144: 0, + 327680: 4198400, + 393216: 2147483712, + 458752: 4194368, + 524288: 2147483648, + 589824: 4194304, + 655360: 64, + 720896: 2147487744, + 786432: 2151678016, + 851968: 4160, + 917504: 4096, + 983040: 2151682112, + 32768: 2147487808, + 98304: 64, + 163840: 2151678016, + 229376: 2147487744, + 294912: 4198400, + 360448: 2151682112, + 425984: 0, + 491520: 2151677952, + 557056: 4096, + 622592: 2151682048, + 688128: 4194304, + 753664: 4160, + 819200: 2147483648, + 884736: 4194368, + 950272: 4198464, + 1015808: 2147483712, + 1048576: 4194368, + 1114112: 4198400, + 1179648: 2147483712, + 1245184: 0, + 1310720: 4160, + 1376256: 2151678016, + 1441792: 2151682048, + 1507328: 2147487808, + 1572864: 2151682112, + 1638400: 2147483648, + 1703936: 2151677952, + 1769472: 4198464, + 1835008: 2147487744, + 1900544: 4194304, + 1966080: 64, + 2031616: 4096, + 1081344: 2151677952, + 1146880: 2151682112, + 1212416: 0, + 1277952: 4198400, + 1343488: 4194368, + 1409024: 2147483648, + 1474560: 2147487808, + 1540096: 64, + 1605632: 2147483712, + 1671168: 4096, + 1736704: 2147487744, + 1802240: 2151678016, + 1867776: 4160, + 1933312: 2151682048, + 1998848: 4194304, + 2064384: 4198464 + }, + { + 0: 128, + 4096: 17039360, + 8192: 262144, + 12288: 536870912, + 16384: 537133184, + 20480: 16777344, + 24576: 553648256, + 28672: 262272, + 32768: 16777216, + 36864: 537133056, + 40960: 536871040, + 45056: 553910400, + 49152: 553910272, + 53248: 0, + 57344: 17039488, + 61440: 553648128, + 2048: 17039488, + 6144: 553648256, + 10240: 128, + 14336: 17039360, + 18432: 262144, + 22528: 537133184, + 26624: 553910272, + 30720: 536870912, + 34816: 537133056, + 38912: 0, + 43008: 553910400, + 47104: 16777344, + 51200: 536871040, + 55296: 553648128, + 59392: 16777216, + 63488: 262272, + 65536: 262144, + 69632: 128, + 73728: 536870912, + 77824: 553648256, + 81920: 16777344, + 86016: 553910272, + 90112: 537133184, + 94208: 16777216, + 98304: 553910400, + 102400: 553648128, + 106496: 17039360, + 110592: 537133056, + 114688: 262272, + 118784: 536871040, + 122880: 0, + 126976: 17039488, + 67584: 553648256, + 71680: 16777216, + 75776: 17039360, + 79872: 537133184, + 83968: 536870912, + 88064: 17039488, + 92160: 128, + 96256: 553910272, + 100352: 262272, + 104448: 553910400, + 108544: 0, + 112640: 553648128, + 116736: 16777344, + 120832: 262144, + 124928: 537133056, + 129024: 536871040 + }, + { + 0: 268435464, + 256: 8192, + 512: 270532608, + 768: 270540808, + 1024: 268443648, + 1280: 2097152, + 1536: 2097160, + 1792: 268435456, + 2048: 0, + 2304: 268443656, + 2560: 2105344, + 2816: 8, + 3072: 270532616, + 3328: 2105352, + 3584: 8200, + 3840: 270540800, + 128: 270532608, + 384: 270540808, + 640: 8, + 896: 2097152, + 1152: 2105352, + 1408: 268435464, + 1664: 268443648, + 1920: 8200, + 2176: 2097160, + 2432: 8192, + 2688: 268443656, + 2944: 270532616, + 3200: 0, + 3456: 270540800, + 3712: 2105344, + 3968: 268435456, + 4096: 268443648, + 4352: 270532616, + 4608: 270540808, + 4864: 8200, + 5120: 2097152, + 5376: 268435456, + 5632: 268435464, + 5888: 2105344, + 6144: 2105352, + 6400: 0, + 6656: 8, + 6912: 270532608, + 7168: 8192, + 7424: 268443656, + 7680: 270540800, + 7936: 2097160, + 4224: 8, + 4480: 2105344, + 4736: 2097152, + 4992: 268435464, + 5248: 268443648, + 5504: 8200, + 5760: 270540808, + 6016: 270532608, + 6272: 270540800, + 6528: 270532616, + 6784: 8192, + 7040: 2105352, + 7296: 2097160, + 7552: 0, + 7808: 268435456, + 8064: 268443656 + }, + { + 0: 1048576, + 16: 33555457, + 32: 1024, + 48: 1049601, + 64: 34604033, + 80: 0, + 96: 1, + 112: 34603009, + 128: 33555456, + 144: 1048577, + 160: 33554433, + 176: 34604032, + 192: 34603008, + 208: 1025, + 224: 1049600, + 240: 33554432, + 8: 34603009, + 24: 0, + 40: 33555457, + 56: 34604032, + 72: 1048576, + 88: 33554433, + 104: 33554432, + 120: 1025, + 136: 1049601, + 152: 33555456, + 168: 34603008, + 184: 1048577, + 200: 1024, + 216: 34604033, + 232: 1, + 248: 1049600, + 256: 33554432, + 272: 1048576, + 288: 33555457, + 304: 34603009, + 320: 1048577, + 336: 33555456, + 352: 34604032, + 368: 1049601, + 384: 1025, + 400: 34604033, + 416: 1049600, + 432: 1, + 448: 0, + 464: 34603008, + 480: 33554433, + 496: 1024, + 264: 1049600, + 280: 33555457, + 296: 34603009, + 312: 1, + 328: 33554432, + 344: 1048576, + 360: 1025, + 376: 34604032, + 392: 33554433, + 408: 34603008, + 424: 0, + 440: 34604033, + 456: 1049601, + 472: 1024, + 488: 33555456, + 504: 1048577 + }, + { + 0: 134219808, + 1: 131072, + 2: 134217728, + 3: 32, + 4: 131104, + 5: 134350880, + 6: 134350848, + 7: 2048, + 8: 134348800, + 9: 134219776, + 10: 133120, + 11: 134348832, + 12: 2080, + 13: 0, + 14: 134217760, + 15: 133152, + 2147483648: 2048, + 2147483649: 134350880, + 2147483650: 134219808, + 2147483651: 134217728, + 2147483652: 134348800, + 2147483653: 133120, + 2147483654: 133152, + 2147483655: 32, + 2147483656: 134217760, + 2147483657: 2080, + 2147483658: 131104, + 2147483659: 134350848, + 2147483660: 0, + 2147483661: 134348832, + 2147483662: 134219776, + 2147483663: 131072, + 16: 133152, + 17: 134350848, + 18: 32, + 19: 2048, + 20: 134219776, + 21: 134217760, + 22: 134348832, + 23: 131072, + 24: 0, + 25: 131104, + 26: 134348800, + 27: 134219808, + 28: 134350880, + 29: 133120, + 30: 2080, + 31: 134217728, + 2147483664: 131072, + 2147483665: 2048, + 2147483666: 134348832, + 2147483667: 133152, + 2147483668: 32, + 2147483669: 134348800, + 2147483670: 134217728, + 2147483671: 134219808, + 2147483672: 134350880, + 2147483673: 134217760, + 2147483674: 134219776, + 2147483675: 0, + 2147483676: 133120, + 2147483677: 2080, + 2147483678: 131104, + 2147483679: 134350848 + } + ]; + var SBOX_MASK = [ + 4160749569, + 528482304, + 33030144, + 2064384, + 129024, + 8064, + 504, + 2147483679 + ]; + var DES = C_algo.DES = BlockCipher.extend({ + _doReset: function() { + var key = this._key; + var keyWords = key.words; + var keyBits = []; + for (var i = 0; i < 56; i++) { + var keyBitPos = PC1[i] - 1; + keyBits[i] = keyWords[keyBitPos >>> 5] >>> 31 - keyBitPos % 32 & 1; + } + var subKeys = this._subKeys = []; + for (var nSubKey = 0; nSubKey < 16; nSubKey++) { + var subKey = subKeys[nSubKey] = []; + var bitShift = BIT_SHIFTS[nSubKey]; + for (var i = 0; i < 24; i++) { + subKey[i / 6 | 0] |= keyBits[(PC2[i] - 1 + bitShift) % 28] << 31 - i % 6; + subKey[4 + (i / 6 | 0)] |= keyBits[28 + (PC2[i + 24] - 1 + bitShift) % 28] << 31 - i % 6; + } + subKey[0] = subKey[0] << 1 | subKey[0] >>> 31; + for (var i = 1; i < 7; i++) { + subKey[i] = subKey[i] >>> (i - 1) * 4 + 3; + } + subKey[7] = subKey[7] << 5 | subKey[7] >>> 27; + } + var invSubKeys = this._invSubKeys = []; + for (var i = 0; i < 16; i++) { + invSubKeys[i] = subKeys[15 - i]; + } + }, + encryptBlock: function(M2, offset) { + this._doCryptBlock(M2, offset, this._subKeys); + }, + decryptBlock: function(M2, offset) { + this._doCryptBlock(M2, offset, this._invSubKeys); + }, + _doCryptBlock: function(M2, offset, subKeys) { + this._lBlock = M2[offset]; + this._rBlock = M2[offset + 1]; + exchangeLR.call(this, 4, 252645135); + exchangeLR.call(this, 16, 65535); + exchangeRL.call(this, 2, 858993459); + exchangeRL.call(this, 8, 16711935); + exchangeLR.call(this, 1, 1431655765); + for (var round = 0; round < 16; round++) { + var subKey = subKeys[round]; + var lBlock = this._lBlock; + var rBlock = this._rBlock; + var f = 0; + for (var i = 0; i < 8; i++) { + f |= SBOX_P[i][((rBlock ^ subKey[i]) & SBOX_MASK[i]) >>> 0]; + } + this._lBlock = rBlock; + this._rBlock = lBlock ^ f; + } + var t = this._lBlock; + this._lBlock = this._rBlock; + this._rBlock = t; + exchangeLR.call(this, 1, 1431655765); + exchangeRL.call(this, 8, 16711935); + exchangeRL.call(this, 2, 858993459); + exchangeLR.call(this, 16, 65535); + exchangeLR.call(this, 4, 252645135); + M2[offset] = this._lBlock; + M2[offset + 1] = this._rBlock; + }, + keySize: 64 / 32, + ivSize: 64 / 32, + blockSize: 64 / 32 + }); + function exchangeLR(offset, mask) { + var t = (this._lBlock >>> offset ^ this._rBlock) & mask; + this._rBlock ^= t; + this._lBlock ^= t << offset; + } + function exchangeRL(offset, mask) { + var t = (this._rBlock >>> offset ^ this._lBlock) & mask; + this._lBlock ^= t; + this._rBlock ^= t << offset; + } + C2.DES = BlockCipher._createHelper(DES); + var TripleDES = C_algo.TripleDES = BlockCipher.extend({ + _doReset: function() { + var key = this._key; + var keyWords = key.words; + if (keyWords.length !== 2 && keyWords.length !== 4 && keyWords.length < 6) { + throw new Error("Invalid key length - 3DES requires the key length to be 64, 128, 192 or >192."); + } + var key1 = keyWords.slice(0, 2); + var key2 = keyWords.length < 4 ? keyWords.slice(0, 2) : keyWords.slice(2, 4); + var key3 = keyWords.length < 6 ? keyWords.slice(0, 2) : keyWords.slice(4, 6); + this._des1 = DES.createEncryptor(WordArray.create(key1)); + this._des2 = DES.createEncryptor(WordArray.create(key2)); + this._des3 = DES.createEncryptor(WordArray.create(key3)); + }, + encryptBlock: function(M2, offset) { + this._des1.encryptBlock(M2, offset); + this._des2.decryptBlock(M2, offset); + this._des3.encryptBlock(M2, offset); + }, + decryptBlock: function(M2, offset) { + this._des3.decryptBlock(M2, offset); + this._des2.encryptBlock(M2, offset); + this._des1.decryptBlock(M2, offset); + }, + keySize: 192 / 32, + ivSize: 64 / 32, + blockSize: 64 / 32 + }); + C2.TripleDES = BlockCipher._createHelper(TripleDES); + })(); + return CryptoJS2.TripleDES; + }); + } +}); + +// node_modules/crypto-js/rc4.js +var require_rc4 = __commonJS({ + "node_modules/crypto-js/rc4.js"(exports, module) { + (function(root, factory, undef) { + if (typeof exports === "object") { + module.exports = exports = factory(require_core(), require_enc_base64(), require_md5(), require_evpkdf(), require_cipher_core()); + } else if (typeof define === "function" && define.amd) { + define(["./core", "./enc-base64", "./md5", "./evpkdf", "./cipher-core"], factory); + } else { + factory(root.CryptoJS); + } + })(exports, function(CryptoJS2) { + (function() { + var C2 = CryptoJS2; + var C_lib = C2.lib; + var StreamCipher = C_lib.StreamCipher; + var C_algo = C2.algo; + var RC4 = C_algo.RC4 = StreamCipher.extend({ + _doReset: function() { + var key = this._key; + var keyWords = key.words; + var keySigBytes = key.sigBytes; + var S = this._S = []; + for (var i = 0; i < 256; i++) { + S[i] = i; + } + for (var i = 0, j = 0; i < 256; i++) { + var keyByteIndex = i % keySigBytes; + var keyByte = keyWords[keyByteIndex >>> 2] >>> 24 - keyByteIndex % 4 * 8 & 255; + j = (j + S[i] + keyByte) % 256; + var t = S[i]; + S[i] = S[j]; + S[j] = t; + } + this._i = this._j = 0; + }, + _doProcessBlock: function(M2, offset) { + M2[offset] ^= generateKeystreamWord.call(this); + }, + keySize: 256 / 32, + ivSize: 0 + }); + function generateKeystreamWord() { + var S = this._S; + var i = this._i; + var j = this._j; + var keystreamWord = 0; + for (var n = 0; n < 4; n++) { + i = (i + 1) % 256; + j = (j + S[i]) % 256; + var t = S[i]; + S[i] = S[j]; + S[j] = t; + keystreamWord |= S[(S[i] + S[j]) % 256] << 24 - n * 8; + } + this._i = i; + this._j = j; + return keystreamWord; + } + C2.RC4 = StreamCipher._createHelper(RC4); + var RC4Drop = C_algo.RC4Drop = RC4.extend({ + /** + * Configuration options. + * + * @property {number} drop The number of keystream words to drop. Default 192 + */ + cfg: RC4.cfg.extend({ + drop: 192 + }), + _doReset: function() { + RC4._doReset.call(this); + for (var i = this.cfg.drop; i > 0; i--) { + generateKeystreamWord.call(this); + } + } + }); + C2.RC4Drop = StreamCipher._createHelper(RC4Drop); + })(); + return CryptoJS2.RC4; + }); + } +}); + +// node_modules/crypto-js/rabbit.js +var require_rabbit = __commonJS({ + "node_modules/crypto-js/rabbit.js"(exports, module) { + (function(root, factory, undef) { + if (typeof exports === "object") { + module.exports = exports = factory(require_core(), require_enc_base64(), require_md5(), require_evpkdf(), require_cipher_core()); + } else if (typeof define === "function" && define.amd) { + define(["./core", "./enc-base64", "./md5", "./evpkdf", "./cipher-core"], factory); + } else { + factory(root.CryptoJS); + } + })(exports, function(CryptoJS2) { + (function() { + var C2 = CryptoJS2; + var C_lib = C2.lib; + var StreamCipher = C_lib.StreamCipher; + var C_algo = C2.algo; + var S = []; + var C_ = []; + var G2 = []; + var Rabbit = C_algo.Rabbit = StreamCipher.extend({ + _doReset: function() { + var K = this._key.words; + var iv = this.cfg.iv; + for (var i = 0; i < 4; i++) { + K[i] = (K[i] << 8 | K[i] >>> 24) & 16711935 | (K[i] << 24 | K[i] >>> 8) & 4278255360; + } + var X = this._X = [ + K[0], + K[3] << 16 | K[2] >>> 16, + K[1], + K[0] << 16 | K[3] >>> 16, + K[2], + K[1] << 16 | K[0] >>> 16, + K[3], + K[2] << 16 | K[1] >>> 16 + ]; + var C3 = this._C = [ + K[2] << 16 | K[2] >>> 16, + K[0] & 4294901760 | K[1] & 65535, + K[3] << 16 | K[3] >>> 16, + K[1] & 4294901760 | K[2] & 65535, + K[0] << 16 | K[0] >>> 16, + K[2] & 4294901760 | K[3] & 65535, + K[1] << 16 | K[1] >>> 16, + K[3] & 4294901760 | K[0] & 65535 + ]; + this._b = 0; + for (var i = 0; i < 4; i++) { + nextState.call(this); + } + for (var i = 0; i < 8; i++) { + C3[i] ^= X[i + 4 & 7]; + } + if (iv) { + var IV = iv.words; + var IV_0 = IV[0]; + var IV_1 = IV[1]; + var i0 = (IV_0 << 8 | IV_0 >>> 24) & 16711935 | (IV_0 << 24 | IV_0 >>> 8) & 4278255360; + var i2 = (IV_1 << 8 | IV_1 >>> 24) & 16711935 | (IV_1 << 24 | IV_1 >>> 8) & 4278255360; + var i1 = i0 >>> 16 | i2 & 4294901760; + var i3 = i2 << 16 | i0 & 65535; + C3[0] ^= i0; + C3[1] ^= i1; + C3[2] ^= i2; + C3[3] ^= i3; + C3[4] ^= i0; + C3[5] ^= i1; + C3[6] ^= i2; + C3[7] ^= i3; + for (var i = 0; i < 4; i++) { + nextState.call(this); + } + } + }, + _doProcessBlock: function(M2, offset) { + var X = this._X; + nextState.call(this); + S[0] = X[0] ^ X[5] >>> 16 ^ X[3] << 16; + S[1] = X[2] ^ X[7] >>> 16 ^ X[5] << 16; + S[2] = X[4] ^ X[1] >>> 16 ^ X[7] << 16; + S[3] = X[6] ^ X[3] >>> 16 ^ X[1] << 16; + for (var i = 0; i < 4; i++) { + S[i] = (S[i] << 8 | S[i] >>> 24) & 16711935 | (S[i] << 24 | S[i] >>> 8) & 4278255360; + M2[offset + i] ^= S[i]; + } + }, + blockSize: 128 / 32, + ivSize: 64 / 32 + }); + function nextState() { + var X = this._X; + var C3 = this._C; + for (var i = 0; i < 8; i++) { + C_[i] = C3[i]; + } + C3[0] = C3[0] + 1295307597 + this._b | 0; + C3[1] = C3[1] + 3545052371 + (C3[0] >>> 0 < C_[0] >>> 0 ? 1 : 0) | 0; + C3[2] = C3[2] + 886263092 + (C3[1] >>> 0 < C_[1] >>> 0 ? 1 : 0) | 0; + C3[3] = C3[3] + 1295307597 + (C3[2] >>> 0 < C_[2] >>> 0 ? 1 : 0) | 0; + C3[4] = C3[4] + 3545052371 + (C3[3] >>> 0 < C_[3] >>> 0 ? 1 : 0) | 0; + C3[5] = C3[5] + 886263092 + (C3[4] >>> 0 < C_[4] >>> 0 ? 1 : 0) | 0; + C3[6] = C3[6] + 1295307597 + (C3[5] >>> 0 < C_[5] >>> 0 ? 1 : 0) | 0; + C3[7] = C3[7] + 3545052371 + (C3[6] >>> 0 < C_[6] >>> 0 ? 1 : 0) | 0; + this._b = C3[7] >>> 0 < C_[7] >>> 0 ? 1 : 0; + for (var i = 0; i < 8; i++) { + var gx = X[i] + C3[i]; + var ga = gx & 65535; + var gb = gx >>> 16; + var gh = ((ga * ga >>> 17) + ga * gb >>> 15) + gb * gb; + var gl = ((gx & 4294901760) * gx | 0) + ((gx & 65535) * gx | 0); + G2[i] = gh ^ gl; + } + X[0] = G2[0] + (G2[7] << 16 | G2[7] >>> 16) + (G2[6] << 16 | G2[6] >>> 16) | 0; + X[1] = G2[1] + (G2[0] << 8 | G2[0] >>> 24) + G2[7] | 0; + X[2] = G2[2] + (G2[1] << 16 | G2[1] >>> 16) + (G2[0] << 16 | G2[0] >>> 16) | 0; + X[3] = G2[3] + (G2[2] << 8 | G2[2] >>> 24) + G2[1] | 0; + X[4] = G2[4] + (G2[3] << 16 | G2[3] >>> 16) + (G2[2] << 16 | G2[2] >>> 16) | 0; + X[5] = G2[5] + (G2[4] << 8 | G2[4] >>> 24) + G2[3] | 0; + X[6] = G2[6] + (G2[5] << 16 | G2[5] >>> 16) + (G2[4] << 16 | G2[4] >>> 16) | 0; + X[7] = G2[7] + (G2[6] << 8 | G2[6] >>> 24) + G2[5] | 0; + } + C2.Rabbit = StreamCipher._createHelper(Rabbit); + })(); + return CryptoJS2.Rabbit; + }); + } +}); + +// node_modules/crypto-js/rabbit-legacy.js +var require_rabbit_legacy = __commonJS({ + "node_modules/crypto-js/rabbit-legacy.js"(exports, module) { + (function(root, factory, undef) { + if (typeof exports === "object") { + module.exports = exports = factory(require_core(), require_enc_base64(), require_md5(), require_evpkdf(), require_cipher_core()); + } else if (typeof define === "function" && define.amd) { + define(["./core", "./enc-base64", "./md5", "./evpkdf", "./cipher-core"], factory); + } else { + factory(root.CryptoJS); + } + })(exports, function(CryptoJS2) { + (function() { + var C2 = CryptoJS2; + var C_lib = C2.lib; + var StreamCipher = C_lib.StreamCipher; + var C_algo = C2.algo; + var S = []; + var C_ = []; + var G2 = []; + var RabbitLegacy = C_algo.RabbitLegacy = StreamCipher.extend({ + _doReset: function() { + var K = this._key.words; + var iv = this.cfg.iv; + var X = this._X = [ + K[0], + K[3] << 16 | K[2] >>> 16, + K[1], + K[0] << 16 | K[3] >>> 16, + K[2], + K[1] << 16 | K[0] >>> 16, + K[3], + K[2] << 16 | K[1] >>> 16 + ]; + var C3 = this._C = [ + K[2] << 16 | K[2] >>> 16, + K[0] & 4294901760 | K[1] & 65535, + K[3] << 16 | K[3] >>> 16, + K[1] & 4294901760 | K[2] & 65535, + K[0] << 16 | K[0] >>> 16, + K[2] & 4294901760 | K[3] & 65535, + K[1] << 16 | K[1] >>> 16, + K[3] & 4294901760 | K[0] & 65535 + ]; + this._b = 0; + for (var i = 0; i < 4; i++) { + nextState.call(this); + } + for (var i = 0; i < 8; i++) { + C3[i] ^= X[i + 4 & 7]; + } + if (iv) { + var IV = iv.words; + var IV_0 = IV[0]; + var IV_1 = IV[1]; + var i0 = (IV_0 << 8 | IV_0 >>> 24) & 16711935 | (IV_0 << 24 | IV_0 >>> 8) & 4278255360; + var i2 = (IV_1 << 8 | IV_1 >>> 24) & 16711935 | (IV_1 << 24 | IV_1 >>> 8) & 4278255360; + var i1 = i0 >>> 16 | i2 & 4294901760; + var i3 = i2 << 16 | i0 & 65535; + C3[0] ^= i0; + C3[1] ^= i1; + C3[2] ^= i2; + C3[3] ^= i3; + C3[4] ^= i0; + C3[5] ^= i1; + C3[6] ^= i2; + C3[7] ^= i3; + for (var i = 0; i < 4; i++) { + nextState.call(this); + } + } + }, + _doProcessBlock: function(M2, offset) { + var X = this._X; + nextState.call(this); + S[0] = X[0] ^ X[5] >>> 16 ^ X[3] << 16; + S[1] = X[2] ^ X[7] >>> 16 ^ X[5] << 16; + S[2] = X[4] ^ X[1] >>> 16 ^ X[7] << 16; + S[3] = X[6] ^ X[3] >>> 16 ^ X[1] << 16; + for (var i = 0; i < 4; i++) { + S[i] = (S[i] << 8 | S[i] >>> 24) & 16711935 | (S[i] << 24 | S[i] >>> 8) & 4278255360; + M2[offset + i] ^= S[i]; + } + }, + blockSize: 128 / 32, + ivSize: 64 / 32 + }); + function nextState() { + var X = this._X; + var C3 = this._C; + for (var i = 0; i < 8; i++) { + C_[i] = C3[i]; + } + C3[0] = C3[0] + 1295307597 + this._b | 0; + C3[1] = C3[1] + 3545052371 + (C3[0] >>> 0 < C_[0] >>> 0 ? 1 : 0) | 0; + C3[2] = C3[2] + 886263092 + (C3[1] >>> 0 < C_[1] >>> 0 ? 1 : 0) | 0; + C3[3] = C3[3] + 1295307597 + (C3[2] >>> 0 < C_[2] >>> 0 ? 1 : 0) | 0; + C3[4] = C3[4] + 3545052371 + (C3[3] >>> 0 < C_[3] >>> 0 ? 1 : 0) | 0; + C3[5] = C3[5] + 886263092 + (C3[4] >>> 0 < C_[4] >>> 0 ? 1 : 0) | 0; + C3[6] = C3[6] + 1295307597 + (C3[5] >>> 0 < C_[5] >>> 0 ? 1 : 0) | 0; + C3[7] = C3[7] + 3545052371 + (C3[6] >>> 0 < C_[6] >>> 0 ? 1 : 0) | 0; + this._b = C3[7] >>> 0 < C_[7] >>> 0 ? 1 : 0; + for (var i = 0; i < 8; i++) { + var gx = X[i] + C3[i]; + var ga = gx & 65535; + var gb = gx >>> 16; + var gh = ((ga * ga >>> 17) + ga * gb >>> 15) + gb * gb; + var gl = ((gx & 4294901760) * gx | 0) + ((gx & 65535) * gx | 0); + G2[i] = gh ^ gl; + } + X[0] = G2[0] + (G2[7] << 16 | G2[7] >>> 16) + (G2[6] << 16 | G2[6] >>> 16) | 0; + X[1] = G2[1] + (G2[0] << 8 | G2[0] >>> 24) + G2[7] | 0; + X[2] = G2[2] + (G2[1] << 16 | G2[1] >>> 16) + (G2[0] << 16 | G2[0] >>> 16) | 0; + X[3] = G2[3] + (G2[2] << 8 | G2[2] >>> 24) + G2[1] | 0; + X[4] = G2[4] + (G2[3] << 16 | G2[3] >>> 16) + (G2[2] << 16 | G2[2] >>> 16) | 0; + X[5] = G2[5] + (G2[4] << 8 | G2[4] >>> 24) + G2[3] | 0; + X[6] = G2[6] + (G2[5] << 16 | G2[5] >>> 16) + (G2[4] << 16 | G2[4] >>> 16) | 0; + X[7] = G2[7] + (G2[6] << 8 | G2[6] >>> 24) + G2[5] | 0; + } + C2.RabbitLegacy = StreamCipher._createHelper(RabbitLegacy); + })(); + return CryptoJS2.RabbitLegacy; + }); + } +}); + +// node_modules/crypto-js/blowfish.js +var require_blowfish = __commonJS({ + "node_modules/crypto-js/blowfish.js"(exports, module) { + (function(root, factory, undef) { + if (typeof exports === "object") { + module.exports = exports = factory(require_core(), require_enc_base64(), require_md5(), require_evpkdf(), require_cipher_core()); + } else if (typeof define === "function" && define.amd) { + define(["./core", "./enc-base64", "./md5", "./evpkdf", "./cipher-core"], factory); + } else { + factory(root.CryptoJS); + } + })(exports, function(CryptoJS2) { + (function() { + var C2 = CryptoJS2; + var C_lib = C2.lib; + var BlockCipher = C_lib.BlockCipher; + var C_algo = C2.algo; + const N2 = 16; + const ORIG_P = [ + 608135816, + 2242054355, + 320440878, + 57701188, + 2752067618, + 698298832, + 137296536, + 3964562569, + 1160258022, + 953160567, + 3193202383, + 887688300, + 3232508343, + 3380367581, + 1065670069, + 3041331479, + 2450970073, + 2306472731 + ]; + const ORIG_S = [ + [ + 3509652390, + 2564797868, + 805139163, + 3491422135, + 3101798381, + 1780907670, + 3128725573, + 4046225305, + 614570311, + 3012652279, + 134345442, + 2240740374, + 1667834072, + 1901547113, + 2757295779, + 4103290238, + 227898511, + 1921955416, + 1904987480, + 2182433518, + 2069144605, + 3260701109, + 2620446009, + 720527379, + 3318853667, + 677414384, + 3393288472, + 3101374703, + 2390351024, + 1614419982, + 1822297739, + 2954791486, + 3608508353, + 3174124327, + 2024746970, + 1432378464, + 3864339955, + 2857741204, + 1464375394, + 1676153920, + 1439316330, + 715854006, + 3033291828, + 289532110, + 2706671279, + 2087905683, + 3018724369, + 1668267050, + 732546397, + 1947742710, + 3462151702, + 2609353502, + 2950085171, + 1814351708, + 2050118529, + 680887927, + 999245976, + 1800124847, + 3300911131, + 1713906067, + 1641548236, + 4213287313, + 1216130144, + 1575780402, + 4018429277, + 3917837745, + 3693486850, + 3949271944, + 596196993, + 3549867205, + 258830323, + 2213823033, + 772490370, + 2760122372, + 1774776394, + 2652871518, + 566650946, + 4142492826, + 1728879713, + 2882767088, + 1783734482, + 3629395816, + 2517608232, + 2874225571, + 1861159788, + 326777828, + 3124490320, + 2130389656, + 2716951837, + 967770486, + 1724537150, + 2185432712, + 2364442137, + 1164943284, + 2105845187, + 998989502, + 3765401048, + 2244026483, + 1075463327, + 1455516326, + 1322494562, + 910128902, + 469688178, + 1117454909, + 936433444, + 3490320968, + 3675253459, + 1240580251, + 122909385, + 2157517691, + 634681816, + 4142456567, + 3825094682, + 3061402683, + 2540495037, + 79693498, + 3249098678, + 1084186820, + 1583128258, + 426386531, + 1761308591, + 1047286709, + 322548459, + 995290223, + 1845252383, + 2603652396, + 3431023940, + 2942221577, + 3202600964, + 3727903485, + 1712269319, + 422464435, + 3234572375, + 1170764815, + 3523960633, + 3117677531, + 1434042557, + 442511882, + 3600875718, + 1076654713, + 1738483198, + 4213154764, + 2393238008, + 3677496056, + 1014306527, + 4251020053, + 793779912, + 2902807211, + 842905082, + 4246964064, + 1395751752, + 1040244610, + 2656851899, + 3396308128, + 445077038, + 3742853595, + 3577915638, + 679411651, + 2892444358, + 2354009459, + 1767581616, + 3150600392, + 3791627101, + 3102740896, + 284835224, + 4246832056, + 1258075500, + 768725851, + 2589189241, + 3069724005, + 3532540348, + 1274779536, + 3789419226, + 2764799539, + 1660621633, + 3471099624, + 4011903706, + 913787905, + 3497959166, + 737222580, + 2514213453, + 2928710040, + 3937242737, + 1804850592, + 3499020752, + 2949064160, + 2386320175, + 2390070455, + 2415321851, + 4061277028, + 2290661394, + 2416832540, + 1336762016, + 1754252060, + 3520065937, + 3014181293, + 791618072, + 3188594551, + 3933548030, + 2332172193, + 3852520463, + 3043980520, + 413987798, + 3465142937, + 3030929376, + 4245938359, + 2093235073, + 3534596313, + 375366246, + 2157278981, + 2479649556, + 555357303, + 3870105701, + 2008414854, + 3344188149, + 4221384143, + 3956125452, + 2067696032, + 3594591187, + 2921233993, + 2428461, + 544322398, + 577241275, + 1471733935, + 610547355, + 4027169054, + 1432588573, + 1507829418, + 2025931657, + 3646575487, + 545086370, + 48609733, + 2200306550, + 1653985193, + 298326376, + 1316178497, + 3007786442, + 2064951626, + 458293330, + 2589141269, + 3591329599, + 3164325604, + 727753846, + 2179363840, + 146436021, + 1461446943, + 4069977195, + 705550613, + 3059967265, + 3887724982, + 4281599278, + 3313849956, + 1404054877, + 2845806497, + 146425753, + 1854211946 + ], + [ + 1266315497, + 3048417604, + 3681880366, + 3289982499, + 290971e4, + 1235738493, + 2632868024, + 2414719590, + 3970600049, + 1771706367, + 1449415276, + 3266420449, + 422970021, + 1963543593, + 2690192192, + 3826793022, + 1062508698, + 1531092325, + 1804592342, + 2583117782, + 2714934279, + 4024971509, + 1294809318, + 4028980673, + 1289560198, + 2221992742, + 1669523910, + 35572830, + 157838143, + 1052438473, + 1016535060, + 1802137761, + 1753167236, + 1386275462, + 3080475397, + 2857371447, + 1040679964, + 2145300060, + 2390574316, + 1461121720, + 2956646967, + 4031777805, + 4028374788, + 33600511, + 2920084762, + 1018524850, + 629373528, + 3691585981, + 3515945977, + 2091462646, + 2486323059, + 586499841, + 988145025, + 935516892, + 3367335476, + 2599673255, + 2839830854, + 265290510, + 3972581182, + 2759138881, + 3795373465, + 1005194799, + 847297441, + 406762289, + 1314163512, + 1332590856, + 1866599683, + 4127851711, + 750260880, + 613907577, + 1450815602, + 3165620655, + 3734664991, + 3650291728, + 3012275730, + 3704569646, + 1427272223, + 778793252, + 1343938022, + 2676280711, + 2052605720, + 1946737175, + 3164576444, + 3914038668, + 3967478842, + 3682934266, + 1661551462, + 3294938066, + 4011595847, + 840292616, + 3712170807, + 616741398, + 312560963, + 711312465, + 1351876610, + 322626781, + 1910503582, + 271666773, + 2175563734, + 1594956187, + 70604529, + 3617834859, + 1007753275, + 1495573769, + 4069517037, + 2549218298, + 2663038764, + 504708206, + 2263041392, + 3941167025, + 2249088522, + 1514023603, + 1998579484, + 1312622330, + 694541497, + 2582060303, + 2151582166, + 1382467621, + 776784248, + 2618340202, + 3323268794, + 2497899128, + 2784771155, + 503983604, + 4076293799, + 907881277, + 423175695, + 432175456, + 1378068232, + 4145222326, + 3954048622, + 3938656102, + 3820766613, + 2793130115, + 2977904593, + 26017576, + 3274890735, + 3194772133, + 1700274565, + 1756076034, + 4006520079, + 3677328699, + 720338349, + 1533947780, + 354530856, + 688349552, + 3973924725, + 1637815568, + 332179504, + 3949051286, + 53804574, + 2852348879, + 3044236432, + 1282449977, + 3583942155, + 3416972820, + 4006381244, + 1617046695, + 2628476075, + 3002303598, + 1686838959, + 431878346, + 2686675385, + 1700445008, + 1080580658, + 1009431731, + 832498133, + 3223435511, + 2605976345, + 2271191193, + 2516031870, + 1648197032, + 4164389018, + 2548247927, + 300782431, + 375919233, + 238389289, + 3353747414, + 2531188641, + 2019080857, + 1475708069, + 455242339, + 2609103871, + 448939670, + 3451063019, + 1395535956, + 2413381860, + 1841049896, + 1491858159, + 885456874, + 4264095073, + 4001119347, + 1565136089, + 3898914787, + 1108368660, + 540939232, + 1173283510, + 2745871338, + 3681308437, + 4207628240, + 3343053890, + 4016749493, + 1699691293, + 1103962373, + 3625875870, + 2256883143, + 3830138730, + 1031889488, + 3479347698, + 1535977030, + 4236805024, + 3251091107, + 2132092099, + 1774941330, + 1199868427, + 1452454533, + 157007616, + 2904115357, + 342012276, + 595725824, + 1480756522, + 206960106, + 497939518, + 591360097, + 863170706, + 2375253569, + 3596610801, + 1814182875, + 2094937945, + 3421402208, + 1082520231, + 3463918190, + 2785509508, + 435703966, + 3908032597, + 1641649973, + 2842273706, + 3305899714, + 1510255612, + 2148256476, + 2655287854, + 3276092548, + 4258621189, + 236887753, + 3681803219, + 274041037, + 1734335097, + 3815195456, + 3317970021, + 1899903192, + 1026095262, + 4050517792, + 356393447, + 2410691914, + 3873677099, + 3682840055 + ], + [ + 3913112168, + 2491498743, + 4132185628, + 2489919796, + 1091903735, + 1979897079, + 3170134830, + 3567386728, + 3557303409, + 857797738, + 1136121015, + 1342202287, + 507115054, + 2535736646, + 337727348, + 3213592640, + 1301675037, + 2528481711, + 1895095763, + 1721773893, + 3216771564, + 62756741, + 2142006736, + 835421444, + 2531993523, + 1442658625, + 3659876326, + 2882144922, + 676362277, + 1392781812, + 170690266, + 3921047035, + 1759253602, + 3611846912, + 1745797284, + 664899054, + 1329594018, + 3901205900, + 3045908486, + 2062866102, + 2865634940, + 3543621612, + 3464012697, + 1080764994, + 553557557, + 3656615353, + 3996768171, + 991055499, + 499776247, + 1265440854, + 648242737, + 3940784050, + 980351604, + 3713745714, + 1749149687, + 3396870395, + 4211799374, + 3640570775, + 1161844396, + 3125318951, + 1431517754, + 545492359, + 4268468663, + 3499529547, + 1437099964, + 2702547544, + 3433638243, + 2581715763, + 2787789398, + 1060185593, + 1593081372, + 2418618748, + 4260947970, + 69676912, + 2159744348, + 86519011, + 2512459080, + 3838209314, + 1220612927, + 3339683548, + 133810670, + 1090789135, + 1078426020, + 1569222167, + 845107691, + 3583754449, + 4072456591, + 1091646820, + 628848692, + 1613405280, + 3757631651, + 526609435, + 236106946, + 48312990, + 2942717905, + 3402727701, + 1797494240, + 859738849, + 992217954, + 4005476642, + 2243076622, + 3870952857, + 3732016268, + 765654824, + 3490871365, + 2511836413, + 1685915746, + 3888969200, + 1414112111, + 2273134842, + 3281911079, + 4080962846, + 172450625, + 2569994100, + 980381355, + 4109958455, + 2819808352, + 2716589560, + 2568741196, + 3681446669, + 3329971472, + 1835478071, + 660984891, + 3704678404, + 4045999559, + 3422617507, + 3040415634, + 1762651403, + 1719377915, + 3470491036, + 2693910283, + 3642056355, + 3138596744, + 1364962596, + 2073328063, + 1983633131, + 926494387, + 3423689081, + 2150032023, + 4096667949, + 1749200295, + 3328846651, + 309677260, + 2016342300, + 1779581495, + 3079819751, + 111262694, + 1274766160, + 443224088, + 298511866, + 1025883608, + 3806446537, + 1145181785, + 168956806, + 3641502830, + 3584813610, + 1689216846, + 3666258015, + 3200248200, + 1692713982, + 2646376535, + 4042768518, + 1618508792, + 1610833997, + 3523052358, + 4130873264, + 2001055236, + 3610705100, + 2202168115, + 4028541809, + 2961195399, + 1006657119, + 2006996926, + 3186142756, + 1430667929, + 3210227297, + 1314452623, + 4074634658, + 4101304120, + 2273951170, + 1399257539, + 3367210612, + 3027628629, + 1190975929, + 2062231137, + 2333990788, + 2221543033, + 2438960610, + 1181637006, + 548689776, + 2362791313, + 3372408396, + 3104550113, + 3145860560, + 296247880, + 1970579870, + 3078560182, + 3769228297, + 1714227617, + 3291629107, + 3898220290, + 166772364, + 1251581989, + 493813264, + 448347421, + 195405023, + 2709975567, + 677966185, + 3703036547, + 1463355134, + 2715995803, + 1338867538, + 1343315457, + 2802222074, + 2684532164, + 233230375, + 2599980071, + 2000651841, + 3277868038, + 1638401717, + 4028070440, + 3237316320, + 6314154, + 819756386, + 300326615, + 590932579, + 1405279636, + 3267499572, + 3150704214, + 2428286686, + 3959192993, + 3461946742, + 1862657033, + 1266418056, + 963775037, + 2089974820, + 2263052895, + 1917689273, + 448879540, + 3550394620, + 3981727096, + 150775221, + 3627908307, + 1303187396, + 508620638, + 2975983352, + 2726630617, + 1817252668, + 1876281319, + 1457606340, + 908771278, + 3720792119, + 3617206836, + 2455994898, + 1729034894, + 1080033504 + ], + [ + 976866871, + 3556439503, + 2881648439, + 1522871579, + 1555064734, + 1336096578, + 3548522304, + 2579274686, + 3574697629, + 3205460757, + 3593280638, + 3338716283, + 3079412587, + 564236357, + 2993598910, + 1781952180, + 1464380207, + 3163844217, + 3332601554, + 1699332808, + 1393555694, + 1183702653, + 3581086237, + 1288719814, + 691649499, + 2847557200, + 2895455976, + 3193889540, + 2717570544, + 1781354906, + 1676643554, + 2592534050, + 3230253752, + 1126444790, + 2770207658, + 2633158820, + 2210423226, + 2615765581, + 2414155088, + 3127139286, + 673620729, + 2805611233, + 1269405062, + 4015350505, + 3341807571, + 4149409754, + 1057255273, + 2012875353, + 2162469141, + 2276492801, + 2601117357, + 993977747, + 3918593370, + 2654263191, + 753973209, + 36408145, + 2530585658, + 25011837, + 3520020182, + 2088578344, + 530523599, + 2918365339, + 1524020338, + 1518925132, + 3760827505, + 3759777254, + 1202760957, + 3985898139, + 3906192525, + 674977740, + 4174734889, + 2031300136, + 2019492241, + 3983892565, + 4153806404, + 3822280332, + 352677332, + 2297720250, + 60907813, + 90501309, + 3286998549, + 1016092578, + 2535922412, + 2839152426, + 457141659, + 509813237, + 4120667899, + 652014361, + 1966332200, + 2975202805, + 55981186, + 2327461051, + 676427537, + 3255491064, + 2882294119, + 3433927263, + 1307055953, + 942726286, + 933058658, + 2468411793, + 3933900994, + 4215176142, + 1361170020, + 2001714738, + 2830558078, + 3274259782, + 1222529897, + 1679025792, + 2729314320, + 3714953764, + 1770335741, + 151462246, + 3013232138, + 1682292957, + 1483529935, + 471910574, + 1539241949, + 458788160, + 3436315007, + 1807016891, + 3718408830, + 978976581, + 1043663428, + 3165965781, + 1927990952, + 4200891579, + 2372276910, + 3208408903, + 3533431907, + 1412390302, + 2931980059, + 4132332400, + 1947078029, + 3881505623, + 4168226417, + 2941484381, + 1077988104, + 1320477388, + 886195818, + 18198404, + 3786409e3, + 2509781533, + 112762804, + 3463356488, + 1866414978, + 891333506, + 18488651, + 661792760, + 1628790961, + 3885187036, + 3141171499, + 876946877, + 2693282273, + 1372485963, + 791857591, + 2686433993, + 3759982718, + 3167212022, + 3472953795, + 2716379847, + 445679433, + 3561995674, + 3504004811, + 3574258232, + 54117162, + 3331405415, + 2381918588, + 3769707343, + 4154350007, + 1140177722, + 4074052095, + 668550556, + 3214352940, + 367459370, + 261225585, + 2610173221, + 4209349473, + 3468074219, + 3265815641, + 314222801, + 3066103646, + 3808782860, + 282218597, + 3406013506, + 3773591054, + 379116347, + 1285071038, + 846784868, + 2669647154, + 3771962079, + 3550491691, + 2305946142, + 453669953, + 1268987020, + 3317592352, + 3279303384, + 3744833421, + 2610507566, + 3859509063, + 266596637, + 3847019092, + 517658769, + 3462560207, + 3443424879, + 370717030, + 4247526661, + 2224018117, + 4143653529, + 4112773975, + 2788324899, + 2477274417, + 1456262402, + 2901442914, + 1517677493, + 1846949527, + 2295493580, + 3734397586, + 2176403920, + 1280348187, + 1908823572, + 3871786941, + 846861322, + 1172426758, + 3287448474, + 3383383037, + 1655181056, + 3139813346, + 901632758, + 1897031941, + 2986607138, + 3066810236, + 3447102507, + 1393639104, + 373351379, + 950779232, + 625454576, + 3124240540, + 4148612726, + 2007998917, + 544563296, + 2244738638, + 2330496472, + 2058025392, + 1291430526, + 424198748, + 50039436, + 29584100, + 3605783033, + 2429876329, + 2791104160, + 1057563949, + 3255363231, + 3075367218, + 3463963227, + 1469046755, + 985887462 + ] + ]; + var BLOWFISH_CTX = { + pbox: [], + sbox: [] + }; + function F(ctx, x) { + let a = x >> 24 & 255; + let b = x >> 16 & 255; + let c = x >> 8 & 255; + let d = x & 255; + let y = ctx.sbox[0][a] + ctx.sbox[1][b]; + y = y ^ ctx.sbox[2][c]; + y = y + ctx.sbox[3][d]; + return y; + } + function BlowFish_Encrypt(ctx, left, right) { + let Xl = left; + let Xr = right; + let temp; + for (let i = 0; i < N2; ++i) { + Xl = Xl ^ ctx.pbox[i]; + Xr = F(ctx, Xl) ^ Xr; + temp = Xl; + Xl = Xr; + Xr = temp; + } + temp = Xl; + Xl = Xr; + Xr = temp; + Xr = Xr ^ ctx.pbox[N2]; + Xl = Xl ^ ctx.pbox[N2 + 1]; + return { left: Xl, right: Xr }; + } + function BlowFish_Decrypt(ctx, left, right) { + let Xl = left; + let Xr = right; + let temp; + for (let i = N2 + 1; i > 1; --i) { + Xl = Xl ^ ctx.pbox[i]; + Xr = F(ctx, Xl) ^ Xr; + temp = Xl; + Xl = Xr; + Xr = temp; + } + temp = Xl; + Xl = Xr; + Xr = temp; + Xr = Xr ^ ctx.pbox[1]; + Xl = Xl ^ ctx.pbox[0]; + return { left: Xl, right: Xr }; + } + function BlowFishInit(ctx, key, keysize) { + for (let Row = 0; Row < 4; Row++) { + ctx.sbox[Row] = []; + for (let Col = 0; Col < 256; Col++) { + ctx.sbox[Row][Col] = ORIG_S[Row][Col]; + } + } + let keyIndex = 0; + for (let index = 0; index < N2 + 2; index++) { + ctx.pbox[index] = ORIG_P[index] ^ key[keyIndex]; + keyIndex++; + if (keyIndex >= keysize) { + keyIndex = 0; + } + } + let Data1 = 0; + let Data2 = 0; + let res = 0; + for (let i = 0; i < N2 + 2; i += 2) { + res = BlowFish_Encrypt(ctx, Data1, Data2); + Data1 = res.left; + Data2 = res.right; + ctx.pbox[i] = Data1; + ctx.pbox[i + 1] = Data2; + } + for (let i = 0; i < 4; i++) { + for (let j = 0; j < 256; j += 2) { + res = BlowFish_Encrypt(ctx, Data1, Data2); + Data1 = res.left; + Data2 = res.right; + ctx.sbox[i][j] = Data1; + ctx.sbox[i][j + 1] = Data2; + } + } + return true; + } + var Blowfish = C_algo.Blowfish = BlockCipher.extend({ + _doReset: function() { + if (this._keyPriorReset === this._key) { + return; + } + var key = this._keyPriorReset = this._key; + var keyWords = key.words; + var keySize = key.sigBytes / 4; + BlowFishInit(BLOWFISH_CTX, keyWords, keySize); + }, + encryptBlock: function(M2, offset) { + var res = BlowFish_Encrypt(BLOWFISH_CTX, M2[offset], M2[offset + 1]); + M2[offset] = res.left; + M2[offset + 1] = res.right; + }, + decryptBlock: function(M2, offset) { + var res = BlowFish_Decrypt(BLOWFISH_CTX, M2[offset], M2[offset + 1]); + M2[offset] = res.left; + M2[offset + 1] = res.right; + }, + blockSize: 64 / 32, + keySize: 128 / 32, + ivSize: 64 / 32 + }); + C2.Blowfish = BlockCipher._createHelper(Blowfish); + })(); + return CryptoJS2.Blowfish; + }); + } +}); + +// node_modules/crypto-js/index.js +var require_crypto_js = __commonJS({ + "node_modules/crypto-js/index.js"(exports, module) { + (function(root, factory, undef) { + if (typeof exports === "object") { + module.exports = exports = factory(require_core(), require_x64_core(), require_lib_typedarrays(), require_enc_utf16(), require_enc_base64(), require_enc_base64url(), require_md5(), require_sha1(), require_sha256(), require_sha224(), require_sha512(), require_sha384(), require_sha3(), require_ripemd160(), require_hmac(), require_pbkdf2(), require_evpkdf(), require_cipher_core(), require_mode_cfb(), require_mode_ctr(), require_mode_ctr_gladman(), require_mode_ofb(), require_mode_ecb(), require_pad_ansix923(), require_pad_iso10126(), require_pad_iso97971(), require_pad_zeropadding(), require_pad_nopadding(), require_format_hex(), require_aes(), require_tripledes(), require_rc4(), require_rabbit(), require_rabbit_legacy(), require_blowfish()); + } else if (typeof define === "function" && define.amd) { + define(["./core", "./x64-core", "./lib-typedarrays", "./enc-utf16", "./enc-base64", "./enc-base64url", "./md5", "./sha1", "./sha256", "./sha224", "./sha512", "./sha384", "./sha3", "./ripemd160", "./hmac", "./pbkdf2", "./evpkdf", "./cipher-core", "./mode-cfb", "./mode-ctr", "./mode-ctr-gladman", "./mode-ofb", "./mode-ecb", "./pad-ansix923", "./pad-iso10126", "./pad-iso97971", "./pad-zeropadding", "./pad-nopadding", "./format-hex", "./aes", "./tripledes", "./rc4", "./rabbit", "./rabbit-legacy", "./blowfish"], factory); + } else { + root.CryptoJS = factory(root.CryptoJS); + } + })(exports, function(CryptoJS2) { + return CryptoJS2; + }); + } +}); + +// (disabled):fs +var require_fs = __commonJS({ + "(disabled):fs"() { + } +}); + +// lib/orlp-ed25519.js +var require_orlp_ed25519 = __commonJS({ + "lib/orlp-ed25519.js"(exports, module) { + "use strict"; + var OrlpEd255192 = (() => { + var _scriptName = typeof document != "undefined" ? document.currentScript?.src : void 0; + return (async function(moduleArg = {}) { + var moduleRtn; + var Module = moduleArg; + var ENVIRONMENT_IS_WEB = typeof window == "object"; + var ENVIRONMENT_IS_WORKER = typeof WorkerGlobalScope != "undefined"; + var ENVIRONMENT_IS_NODE = typeof process == "object" && process.versions?.node && process.type != "renderer"; + var arguments_ = []; + var thisProgram = "./this.program"; + var quit_ = (status, toThrow) => { + throw toThrow; + }; + if (typeof __filename != "undefined") { + _scriptName = __filename; + } else if (ENVIRONMENT_IS_WORKER) { + _scriptName = self.location.href; + } + var scriptDirectory = ""; + function locateFile(path) { + if (Module["locateFile"]) { + return Module["locateFile"](path, scriptDirectory); + } + return scriptDirectory + path; + } + var readAsync, readBinary; + if (ENVIRONMENT_IS_NODE) { + var fs = require_fs(); + scriptDirectory = __dirname + "/"; + readBinary = (filename) => { + filename = isFileURI(filename) ? new URL(filename) : filename; + var ret = fs.readFileSync(filename); + return ret; + }; + readAsync = async (filename, binary = true) => { + filename = isFileURI(filename) ? new URL(filename) : filename; + var ret = fs.readFileSync(filename, binary ? void 0 : "utf8"); + return ret; + }; + if (process.argv.length > 1) { + thisProgram = process.argv[1].replace(/\\/g, "/"); + } + arguments_ = process.argv.slice(2); + quit_ = (status, toThrow) => { + process.exitCode = status; + throw toThrow; + }; + } else if (ENVIRONMENT_IS_WEB || ENVIRONMENT_IS_WORKER) { + try { + scriptDirectory = new URL(".", _scriptName).href; + } catch { + } + { + if (ENVIRONMENT_IS_WORKER) { + readBinary = (url) => { + var xhr = new XMLHttpRequest(); + xhr.open("GET", url, false); + xhr.responseType = "arraybuffer"; + xhr.send(null); + return new Uint8Array(xhr.response); + }; + } + readAsync = async (url) => { + if (isFileURI(url)) { + return new Promise((resolve, reject) => { + var xhr = new XMLHttpRequest(); + xhr.open("GET", url, true); + xhr.responseType = "arraybuffer"; + xhr.onload = () => { + if (xhr.status == 200 || xhr.status == 0 && xhr.response) { + resolve(xhr.response); + return; + } + reject(xhr.status); + }; + xhr.onerror = reject; + xhr.send(null); + }); + } + var response = await fetch(url, { credentials: "same-origin" }); + if (response.ok) { + return response.arrayBuffer(); + } + throw new Error(response.status + " : " + response.url); + }; + } + } else { + } + var out = console.log.bind(console); + var err2 = console.error.bind(console); + var wasmBinary; + var ABORT = false; + var isFileURI = (filename) => filename.startsWith("file://"); + var readyPromiseResolve, readyPromiseReject; + var wasmMemory; + var HEAP8, HEAPU8, HEAP16, HEAPU16, HEAP32, HEAPU32, HEAPF32, HEAPF64; + var HEAP64, HEAPU64; + var runtimeInitialized = false; + function updateMemoryViews() { + var b = wasmMemory.buffer; + Module["HEAP8"] = HEAP8 = new Int8Array(b); + HEAP16 = new Int16Array(b); + Module["HEAPU8"] = HEAPU8 = new Uint8Array(b); + HEAPU16 = new Uint16Array(b); + Module["HEAP32"] = HEAP32 = new Int32Array(b); + Module["HEAPU32"] = HEAPU32 = new Uint32Array(b); + HEAPF32 = new Float32Array(b); + HEAPF64 = new Float64Array(b); + HEAP64 = new BigInt64Array(b); + HEAPU64 = new BigUint64Array(b); + } + function preRun() { + if (Module["preRun"]) { + if (typeof Module["preRun"] == "function") Module["preRun"] = [Module["preRun"]]; + while (Module["preRun"].length) { + addOnPreRun(Module["preRun"].shift()); + } + } + callRuntimeCallbacks(onPreRuns); + } + function initRuntime() { + runtimeInitialized = true; + wasmExports["b"](); + } + function postRun() { + if (Module["postRun"]) { + if (typeof Module["postRun"] == "function") Module["postRun"] = [Module["postRun"]]; + while (Module["postRun"].length) { + addOnPostRun(Module["postRun"].shift()); + } + } + callRuntimeCallbacks(onPostRuns); + } + var runDependencies = 0; + var dependenciesFulfilled = null; + function addRunDependency(id) { + runDependencies++; + Module["monitorRunDependencies"]?.(runDependencies); + } + function removeRunDependency(id) { + runDependencies--; + Module["monitorRunDependencies"]?.(runDependencies); + if (runDependencies == 0) { + if (dependenciesFulfilled) { + var callback = dependenciesFulfilled; + dependenciesFulfilled = null; + callback(); + } + } + } + function abort(what) { + Module["onAbort"]?.(what); + what = "Aborted(" + what + ")"; + err2(what); + ABORT = true; + what += ". Build with -sASSERTIONS for more info."; + var e = new WebAssembly.RuntimeError(what); + readyPromiseReject?.(e); + throw e; + } + var wasmBinaryFile; + function findWasmBinary() { + return locateFile("orlp-ed25519.wasm"); + } + function getBinarySync(file) { + if (file == wasmBinaryFile && wasmBinary) { + return new Uint8Array(wasmBinary); + } + if (readBinary) { + return readBinary(file); + } + throw "both async and sync fetching of the wasm failed"; + } + async function getWasmBinary(binaryFile) { + if (!wasmBinary) { + try { + var response = await readAsync(binaryFile); + return new Uint8Array(response); + } catch { + } + } + return getBinarySync(binaryFile); + } + async function instantiateArrayBuffer(binaryFile, imports) { + try { + var binary = await getWasmBinary(binaryFile); + var instance = await WebAssembly.instantiate(binary, imports); + return instance; + } catch (reason) { + err2(`failed to asynchronously prepare wasm: ${reason}`); + abort(reason); + } + } + async function instantiateAsync(binary, binaryFile, imports) { + if (!binary && typeof WebAssembly.instantiateStreaming == "function" && !isFileURI(binaryFile) && !ENVIRONMENT_IS_NODE) { + try { + var response = fetch(binaryFile, { credentials: "same-origin" }); + var instantiationResult = await WebAssembly.instantiateStreaming(response, imports); + return instantiationResult; + } catch (reason) { + err2(`wasm streaming compile failed: ${reason}`); + err2("falling back to ArrayBuffer instantiation"); + } + } + return instantiateArrayBuffer(binaryFile, imports); + } + function getWasmImports() { + return { a: wasmImports }; + } + async function createWasm() { + function receiveInstance(instance, module2) { + wasmExports = instance.exports; + wasmMemory = wasmExports["a"]; + updateMemoryViews(); + assignWasmExports(wasmExports); + removeRunDependency("wasm-instantiate"); + return wasmExports; + } + addRunDependency("wasm-instantiate"); + function receiveInstantiationResult(result2) { + return receiveInstance(result2["instance"]); + } + var info = getWasmImports(); + if (Module["instantiateWasm"]) { + return new Promise((resolve, reject) => { + Module["instantiateWasm"](info, (mod, inst) => { + resolve(receiveInstance(mod, inst)); + }); + }); + } + wasmBinaryFile ??= findWasmBinary(); + var result = await instantiateAsync(wasmBinary, wasmBinaryFile, info); + var exports2 = receiveInstantiationResult(result); + return exports2; + } + class ExitStatus { + name = "ExitStatus"; + constructor(status) { + this.message = `Program terminated with exit(${status})`; + this.status = status; + } + } + var callRuntimeCallbacks = (callbacks) => { + while (callbacks.length > 0) { + callbacks.shift()(Module); + } + }; + var onPostRuns = []; + var addOnPostRun = (cb) => onPostRuns.push(cb); + var onPreRuns = []; + var addOnPreRun = (cb) => onPreRuns.push(cb); + var noExitRuntime = true; + var stackRestore = (val) => __emscripten_stack_restore(val); + var stackSave = () => _emscripten_stack_get_current(); + var getCFunc = (ident) => { + var func = Module["_" + ident]; + return func; + }; + var writeArrayToMemory = (array, buffer) => { + HEAP8.set(array, buffer); + }; + var lengthBytesUTF8 = (str) => { + var len = 0; + for (var i = 0; i < str.length; ++i) { + var c = str.charCodeAt(i); + if (c <= 127) { + len++; + } else if (c <= 2047) { + len += 2; + } else if (c >= 55296 && c <= 57343) { + len += 4; + ++i; + } else { + len += 3; + } + } + return len; + }; + var stringToUTF8Array = (str, heap, outIdx, maxBytesToWrite) => { + if (!(maxBytesToWrite > 0)) return 0; + var startIdx = outIdx; + var endIdx = outIdx + maxBytesToWrite - 1; + for (var i = 0; i < str.length; ++i) { + var u = str.codePointAt(i); + if (u <= 127) { + if (outIdx >= endIdx) break; + heap[outIdx++] = u; + } else if (u <= 2047) { + if (outIdx + 1 >= endIdx) break; + heap[outIdx++] = 192 | u >> 6; + heap[outIdx++] = 128 | u & 63; + } else if (u <= 65535) { + if (outIdx + 2 >= endIdx) break; + heap[outIdx++] = 224 | u >> 12; + heap[outIdx++] = 128 | u >> 6 & 63; + heap[outIdx++] = 128 | u & 63; + } else { + if (outIdx + 3 >= endIdx) break; + heap[outIdx++] = 240 | u >> 18; + heap[outIdx++] = 128 | u >> 12 & 63; + heap[outIdx++] = 128 | u >> 6 & 63; + heap[outIdx++] = 128 | u & 63; + i++; + } + } + heap[outIdx] = 0; + return outIdx - startIdx; + }; + var stringToUTF8 = (str, outPtr, maxBytesToWrite) => stringToUTF8Array(str, HEAPU8, outPtr, maxBytesToWrite); + var stackAlloc = (sz) => __emscripten_stack_alloc(sz); + var stringToUTF8OnStack = (str) => { + var size = lengthBytesUTF8(str) + 1; + var ret = stackAlloc(size); + stringToUTF8(str, ret, size); + return ret; + }; + var UTF8Decoder = typeof TextDecoder != "undefined" ? new TextDecoder() : void 0; + var UTF8ArrayToString = (heapOrArray, idx = 0, maxBytesToRead = NaN) => { + var endIdx = idx + maxBytesToRead; + var endPtr = idx; + while (heapOrArray[endPtr] && !(endPtr >= endIdx)) ++endPtr; + if (endPtr - idx > 16 && heapOrArray.buffer && UTF8Decoder) { + return UTF8Decoder.decode(heapOrArray.subarray(idx, endPtr)); + } + var str = ""; + while (idx < endPtr) { + var u0 = heapOrArray[idx++]; + if (!(u0 & 128)) { + str += String.fromCharCode(u0); + continue; + } + var u1 = heapOrArray[idx++] & 63; + if ((u0 & 224) == 192) { + str += String.fromCharCode((u0 & 31) << 6 | u1); + continue; + } + var u2 = heapOrArray[idx++] & 63; + if ((u0 & 240) == 224) { + u0 = (u0 & 15) << 12 | u1 << 6 | u2; + } else { + u0 = (u0 & 7) << 18 | u1 << 12 | u2 << 6 | heapOrArray[idx++] & 63; + } + if (u0 < 65536) { + str += String.fromCharCode(u0); + } else { + var ch = u0 - 65536; + str += String.fromCharCode(55296 | ch >> 10, 56320 | ch & 1023); + } + } + return str; + }; + var UTF8ToString = (ptr, maxBytesToRead) => ptr ? UTF8ArrayToString(HEAPU8, ptr, maxBytesToRead) : ""; + var ccall = (ident, returnType, argTypes, args, opts) => { + var toC = { string: (str) => { + var ret2 = 0; + if (str !== null && str !== void 0 && str !== 0) { + ret2 = stringToUTF8OnStack(str); + } + return ret2; + }, array: (arr) => { + var ret2 = stackAlloc(arr.length); + writeArrayToMemory(arr, ret2); + return ret2; + } }; + function convertReturnValue(ret2) { + if (returnType === "string") { + return UTF8ToString(ret2); + } + if (returnType === "boolean") return Boolean(ret2); + return ret2; + } + var func = getCFunc(ident); + var cArgs = []; + var stack = 0; + if (args) { + for (var i = 0; i < args.length; i++) { + var converter = toC[argTypes[i]]; + if (converter) { + if (stack === 0) stack = stackSave(); + cArgs[i] = converter(args[i]); + } else { + cArgs[i] = args[i]; + } + } + } + var ret = func(...cArgs); + function onDone(ret2) { + if (stack !== 0) stackRestore(stack); + return convertReturnValue(ret2); + } + ret = onDone(ret); + return ret; + }; + var cwrap = (ident, returnType, argTypes, opts) => { + var numericArgs = !argTypes || argTypes.every((type) => type === "number" || type === "boolean"); + var numericRet = returnType !== "string"; + if (numericRet && numericArgs && !opts) { + return getCFunc(ident); + } + return (...args) => ccall(ident, returnType, argTypes, args, opts); + }; + { + if (Module["noExitRuntime"]) noExitRuntime = Module["noExitRuntime"]; + if (Module["print"]) out = Module["print"]; + if (Module["printErr"]) err2 = Module["printErr"]; + if (Module["wasmBinary"]) wasmBinary = Module["wasmBinary"]; + if (Module["arguments"]) arguments_ = Module["arguments"]; + if (Module["thisProgram"]) thisProgram = Module["thisProgram"]; + } + Module["ccall"] = ccall; + Module["cwrap"] = cwrap; + var _orlp_derive_public_key, _orlp_validate_keypair, _orlp_sign, _orlp_verify, __emscripten_stack_restore, __emscripten_stack_alloc, _emscripten_stack_get_current; + function assignWasmExports(wasmExports2) { + Module["_orlp_derive_public_key"] = _orlp_derive_public_key = wasmExports2["c"]; + Module["_orlp_validate_keypair"] = _orlp_validate_keypair = wasmExports2["d"]; + Module["_orlp_sign"] = _orlp_sign = wasmExports2["e"]; + Module["_orlp_verify"] = _orlp_verify = wasmExports2["f"]; + __emscripten_stack_restore = wasmExports2["g"]; + __emscripten_stack_alloc = wasmExports2["h"]; + _emscripten_stack_get_current = wasmExports2["i"]; + } + var wasmImports = {}; + var wasmExports = await createWasm(); + function run() { + if (runDependencies > 0) { + dependenciesFulfilled = run; + return; + } + preRun(); + if (runDependencies > 0) { + dependenciesFulfilled = run; + return; + } + function doRun() { + Module["calledRun"] = true; + if (ABORT) return; + initRuntime(); + readyPromiseResolve?.(Module); + Module["onRuntimeInitialized"]?.(); + postRun(); + } + if (Module["setStatus"]) { + Module["setStatus"]("Running..."); + setTimeout(() => { + setTimeout(() => Module["setStatus"](""), 1); + doRun(); + }, 1); + } else { + doRun(); + } + } + function preInit() { + if (Module["preInit"]) { + if (typeof Module["preInit"] == "function") Module["preInit"] = [Module["preInit"]]; + while (Module["preInit"].length > 0) { + Module["preInit"].shift()(); + } + } + } + preInit(); + run(); + if (runtimeInitialized) { + moduleRtn = Module; + } else { + moduleRtn = new Promise((resolve, reject) => { + readyPromiseResolve = resolve; + readyPromiseReject = reject; + }); + } + return moduleRtn; + }); + })(); + if (typeof exports === "object" && typeof module === "object") { + module.exports = OrlpEd255192; + module.exports.default = OrlpEd255192; + } else if (typeof define === "function" && define["amd"]) + define([], () => OrlpEd255192); + } +}); + +// node_modules/@noble/ed25519/index.js +var ed25519_exports = {}; +__export(ed25519_exports, { + CURVE: () => ed25519_CURVE, + ExtendedPoint: () => Point, + Point: () => Point, + etc: () => etc, + getPublicKey: () => getPublicKey, + getPublicKeyAsync: () => getPublicKeyAsync, + sign: () => sign, + signAsync: () => signAsync, + utils: () => utils, + verify: () => verify, + verifyAsync: () => verifyAsync +}); +var ed25519_CURVE = { + p: 0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffedn, + n: 0x1000000000000000000000000000000014def9dea2f79cd65812631a5cf5d3edn, + h: 8n, + a: 0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffecn, + d: 0x52036cee2b6ffe738cc740797779e89800700a4d4141d8ab75eb4dca135978a3n, + Gx: 0x216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51an, + Gy: 0x6666666666666666666666666666666666666666666666666666666666666658n +}; +var { p: P, n: N, Gx, Gy, a: _a, d: _d } = ed25519_CURVE; +var h = 8n; +var L = 32; +var L2 = 64; +var err = (m = "") => { + throw new Error(m); +}; +var isBig = (n) => typeof n === "bigint"; +var isStr = (s) => typeof s === "string"; +var isBytes = (a) => a instanceof Uint8Array || ArrayBuffer.isView(a) && a.constructor.name === "Uint8Array"; +var abytes = (a, l) => !isBytes(a) || typeof l === "number" && l > 0 && a.length !== l ? err("Uint8Array expected") : a; +var u8n = (len) => new Uint8Array(len); +var u8fr = (buf) => Uint8Array.from(buf); +var padh = (n, pad2) => n.toString(16).padStart(pad2, "0"); +var bytesToHex = (b) => Array.from(abytes(b)).map((e) => padh(e, 2)).join(""); +var C = { _0: 48, _9: 57, A: 65, F: 70, a: 97, f: 102 }; +var _ch = (ch) => { + if (ch >= C._0 && ch <= C._9) + return ch - C._0; + if (ch >= C.A && ch <= C.F) + return ch - (C.A - 10); + if (ch >= C.a && ch <= C.f) + return ch - (C.a - 10); + return; +}; +var hexToBytes = (hex) => { + const e = "hex invalid"; + if (!isStr(hex)) + return err(e); + const hl = hex.length; + const al = hl / 2; + if (hl % 2) + return err(e); + const array = u8n(al); + for (let ai = 0, hi = 0; ai < al; ai++, hi += 2) { + const n1 = _ch(hex.charCodeAt(hi)); + const n2 = _ch(hex.charCodeAt(hi + 1)); + if (n1 === void 0 || n2 === void 0) + return err(e); + array[ai] = n1 * 16 + n2; + } + return array; +}; +var toU8 = (a, len) => abytes(isStr(a) ? hexToBytes(a) : u8fr(abytes(a)), len); +var cr = () => globalThis?.crypto; +var subtle = () => cr()?.subtle ?? err("crypto.subtle must be defined"); +var concatBytes = (...arrs) => { + const r = u8n(arrs.reduce((sum, a) => sum + abytes(a).length, 0)); + let pad2 = 0; + arrs.forEach((a) => { + r.set(a, pad2); + pad2 += a.length; + }); + return r; +}; +var randomBytes = (len = L) => { + const c = cr(); + return c.getRandomValues(u8n(len)); +}; +var big = BigInt; +var arange = (n, min, max, msg = "bad number: out of range") => isBig(n) && min <= n && n < max ? n : err(msg); +var M = (a, b = P) => { + const r = a % b; + return r >= 0n ? r : b + r; +}; +var modN = (a) => M(a, N); +var invert = (num, md) => { + if (num === 0n || md <= 0n) + err("no inverse n=" + num + " mod=" + md); + let a = M(num, md), b = md, x = 0n, y = 1n, u = 1n, v = 0n; + while (a !== 0n) { + const q = b / a, r = b % a; + const m = x - u * q, n = y - v * q; + b = a, a = r, x = u, y = v, u = m, v = n; + } + return b === 1n ? M(x, md) : err("no inverse"); +}; +var callHash = (name) => { + const fn = etc[name]; + if (typeof fn !== "function") + err("hashes." + name + " not set"); + return fn; +}; +var apoint = (p) => p instanceof Point ? p : err("Point expected"); +var B256 = 2n ** 256n; +var Point = class _Point { + static BASE; + static ZERO; + ex; + ey; + ez; + et; + constructor(ex, ey, ez, et) { + const max = B256; + this.ex = arange(ex, 0n, max); + this.ey = arange(ey, 0n, max); + this.ez = arange(ez, 1n, max); + this.et = arange(et, 0n, max); + Object.freeze(this); + } + static fromAffine(p) { + return new _Point(p.x, p.y, 1n, M(p.x * p.y)); + } + /** RFC8032 5.1.3: Uint8Array to Point. */ + static fromBytes(hex, zip215 = false) { + const d = _d; + const normed = u8fr(abytes(hex, L)); + const lastByte = hex[31]; + normed[31] = lastByte & ~128; + const y = bytesToNumLE(normed); + const max = zip215 ? B256 : P; + arange(y, 0n, max); + const y2 = M(y * y); + const u = M(y2 - 1n); + const v = M(d * y2 + 1n); + let { isValid, value: x } = uvRatio(u, v); + if (!isValid) + err("bad point: y not sqrt"); + const isXOdd = (x & 1n) === 1n; + const isLastByteOdd = (lastByte & 128) !== 0; + if (!zip215 && x === 0n && isLastByteOdd) + err("bad point: x==0, isLastByteOdd"); + if (isLastByteOdd !== isXOdd) + x = M(-x); + return new _Point(x, y, 1n, M(x * y)); + } + /** Checks if the point is valid and on-curve. */ + assertValidity() { + const a = _a; + const d = _d; + const p = this; + if (p.is0()) + throw new Error("bad point: ZERO"); + const { ex: X, ey: Y, ez: Z, et: T } = p; + const X2 = M(X * X); + const Y2 = M(Y * Y); + const Z2 = M(Z * Z); + const Z4 = M(Z2 * Z2); + const aX2 = M(X2 * a); + const left = M(Z2 * M(aX2 + Y2)); + const right = M(Z4 + M(d * M(X2 * Y2))); + if (left !== right) + throw new Error("bad point: equation left != right (1)"); + const XY = M(X * Y); + const ZT = M(Z * T); + if (XY !== ZT) + throw new Error("bad point: equation left != right (2)"); + return this; + } + /** Equality check: compare points P&Q. */ + equals(other) { + const { ex: X1, ey: Y1, ez: Z1 } = this; + const { ex: X2, ey: Y2, ez: Z2 } = apoint(other); + const X1Z2 = M(X1 * Z2); + const X2Z1 = M(X2 * Z1); + const Y1Z2 = M(Y1 * Z2); + const Y2Z1 = M(Y2 * Z1); + return X1Z2 === X2Z1 && Y1Z2 === Y2Z1; + } + is0() { + return this.equals(I); + } + /** Flip point over y coordinate. */ + negate() { + return new _Point(M(-this.ex), this.ey, this.ez, M(-this.et)); + } + /** Point doubling. Complete formula. Cost: `4M + 4S + 1*a + 6add + 1*2`. */ + double() { + const { ex: X1, ey: Y1, ez: Z1 } = this; + const a = _a; + const A = M(X1 * X1); + const B = M(Y1 * Y1); + const C2 = M(2n * M(Z1 * Z1)); + const D = M(a * A); + const x1y1 = X1 + Y1; + const E = M(M(x1y1 * x1y1) - A - B); + const G2 = D + B; + const F = G2 - C2; + const H = D - B; + const X3 = M(E * F); + const Y3 = M(G2 * H); + const T3 = M(E * H); + const Z3 = M(F * G2); + return new _Point(X3, Y3, Z3, T3); + } + /** Point addition. Complete formula. Cost: `8M + 1*k + 8add + 1*2`. */ + add(other) { + const { ex: X1, ey: Y1, ez: Z1, et: T1 } = this; + const { ex: X2, ey: Y2, ez: Z2, et: T2 } = apoint(other); + const a = _a; + const d = _d; + const A = M(X1 * X2); + const B = M(Y1 * Y2); + const C2 = M(T1 * d * T2); + const D = M(Z1 * Z2); + const E = M((X1 + Y1) * (X2 + Y2) - A - B); + const F = M(D - C2); + const G2 = M(D + C2); + const H = M(B - a * A); + const X3 = M(E * F); + const Y3 = M(G2 * H); + const T3 = M(E * H); + const Z3 = M(F * G2); + return new _Point(X3, Y3, Z3, T3); + } + /** + * Point-by-scalar multiplication. Scalar must be in range 1 <= n < CURVE.n. + * Uses {@link wNAF} for base point. + * Uses fake point to mitigate side-channel leakage. + * @param n scalar by which point is multiplied + * @param safe safe mode guards against timing attacks; unsafe mode is faster + */ + multiply(n, safe = true) { + if (!safe && (n === 0n || this.is0())) + return I; + arange(n, 1n, N); + if (n === 1n) + return this; + if (this.equals(G)) + return wNAF(n).p; + let p = I; + let f = G; + for (let d = this; n > 0n; d = d.double(), n >>= 1n) { + if (n & 1n) + p = p.add(d); + else if (safe) + f = f.add(d); + } + return p; + } + /** Convert point to 2d xy affine point. (X, Y, Z) ∋ (x=X/Z, y=Y/Z) */ + toAffine() { + const { ex: x, ey: y, ez: z } = this; + if (this.equals(I)) + return { x: 0n, y: 1n }; + const iz = invert(z, P); + if (M(z * iz) !== 1n) + err("invalid inverse"); + return { x: M(x * iz), y: M(y * iz) }; + } + toBytes() { + const { x, y } = this.assertValidity().toAffine(); + const b = numTo32bLE(y); + b[31] |= x & 1n ? 128 : 0; + return b; + } + toHex() { + return bytesToHex(this.toBytes()); + } + // encode to hex string + clearCofactor() { + return this.multiply(big(h), false); + } + isSmallOrder() { + return this.clearCofactor().is0(); + } + isTorsionFree() { + let p = this.multiply(N / 2n, false).double(); + if (N % 2n) + p = p.add(this); + return p.is0(); + } + static fromHex(hex, zip215) { + return _Point.fromBytes(toU8(hex), zip215); + } + get x() { + return this.toAffine().x; + } + get y() { + return this.toAffine().y; + } + toRawBytes() { + return this.toBytes(); + } +}; +var G = new Point(Gx, Gy, 1n, M(Gx * Gy)); +var I = new Point(0n, 1n, 1n, 0n); +Point.BASE = G; +Point.ZERO = I; +var numTo32bLE = (num) => hexToBytes(padh(arange(num, 0n, B256), L2)).reverse(); +var bytesToNumLE = (b) => big("0x" + bytesToHex(u8fr(abytes(b)).reverse())); +var pow2 = (x, power) => { + let r = x; + while (power-- > 0n) { + r *= r; + r %= P; + } + return r; +}; +var pow_2_252_3 = (x) => { + const x2 = x * x % P; + const b2 = x2 * x % P; + const b4 = pow2(b2, 2n) * b2 % P; + const b5 = pow2(b4, 1n) * x % P; + const b10 = pow2(b5, 5n) * b5 % P; + const b20 = pow2(b10, 10n) * b10 % P; + const b40 = pow2(b20, 20n) * b20 % P; + const b80 = pow2(b40, 40n) * b40 % P; + const b160 = pow2(b80, 80n) * b80 % P; + const b240 = pow2(b160, 80n) * b80 % P; + const b250 = pow2(b240, 10n) * b10 % P; + const pow_p_5_8 = pow2(b250, 2n) * x % P; + return { pow_p_5_8, b2 }; +}; +var RM1 = 0x2b8324804fc1df0b2b4d00993dfbd7a72f431806ad2fe478c4ee1b274a0ea0b0n; +var uvRatio = (u, v) => { + const v3 = M(v * v * v); + const v7 = M(v3 * v3 * v); + const pow = pow_2_252_3(u * v7).pow_p_5_8; + let x = M(u * v3 * pow); + const vx2 = M(v * x * x); + const root1 = x; + const root2 = M(x * RM1); + const useRoot1 = vx2 === u; + const useRoot2 = vx2 === M(-u); + const noRoot = vx2 === M(-u * RM1); + if (useRoot1) + x = root1; + if (useRoot2 || noRoot) + x = root2; + if ((M(x) & 1n) === 1n) + x = M(-x); + return { isValid: useRoot1 || useRoot2, value: x }; +}; +var modL_LE = (hash) => modN(bytesToNumLE(hash)); +var sha512a = (...m) => etc.sha512Async(...m); +var sha512s = (...m) => callHash("sha512Sync")(...m); +var hash2extK = (hashed) => { + const head = hashed.slice(0, L); + head[0] &= 248; + head[31] &= 127; + head[31] |= 64; + const prefix = hashed.slice(L, L2); + const scalar = modL_LE(head); + const point = G.multiply(scalar); + const pointBytes = point.toBytes(); + return { head, prefix, scalar, point, pointBytes }; +}; +var getExtendedPublicKeyAsync = (priv) => sha512a(toU8(priv, L)).then(hash2extK); +var getExtendedPublicKey = (priv) => hash2extK(sha512s(toU8(priv, L))); +var getPublicKeyAsync = (priv) => getExtendedPublicKeyAsync(priv).then((p) => p.pointBytes); +var getPublicKey = (priv) => getExtendedPublicKey(priv).pointBytes; +var hashFinishA = (res) => sha512a(res.hashable).then(res.finish); +var hashFinishS = (res) => res.finish(sha512s(res.hashable)); +var _sign = (e, rBytes, msg) => { + const { pointBytes: P2, scalar: s } = e; + const r = modL_LE(rBytes); + const R = G.multiply(r).toBytes(); + const hashable = concatBytes(R, P2, msg); + const finish = (hashed) => { + const S = modN(r + modL_LE(hashed) * s); + return abytes(concatBytes(R, numTo32bLE(S)), L2); + }; + return { hashable, finish }; +}; +var signAsync = async (msg, privKey) => { + const m = toU8(msg); + const e = await getExtendedPublicKeyAsync(privKey); + const rBytes = await sha512a(e.prefix, m); + return hashFinishA(_sign(e, rBytes, m)); +}; +var sign = (msg, privKey) => { + const m = toU8(msg); + const e = getExtendedPublicKey(privKey); + const rBytes = sha512s(e.prefix, m); + return hashFinishS(_sign(e, rBytes, m)); +}; +var veriOpts = { zip215: true }; +var _verify = (sig, msg, pub, opts = veriOpts) => { + sig = toU8(sig, L2); + msg = toU8(msg); + pub = toU8(pub, L); + const { zip215 } = opts; + let A; + let R; + let s; + let SB; + let hashable = Uint8Array.of(); + try { + A = Point.fromHex(pub, zip215); + R = Point.fromHex(sig.slice(0, L), zip215); + s = bytesToNumLE(sig.slice(L, L2)); + SB = G.multiply(s, false); + hashable = concatBytes(R.toBytes(), A.toBytes(), msg); + } catch (error) { + } + const finish = (hashed) => { + if (SB == null) + return false; + if (!zip215 && A.isSmallOrder()) + return false; + const k = modL_LE(hashed); + const RkA = R.add(A.multiply(k, false)); + return RkA.add(SB.negate()).clearCofactor().is0(); + }; + return { hashable, finish }; +}; +var verifyAsync = async (s, m, p, opts = veriOpts) => hashFinishA(_verify(s, m, p, opts)); +var verify = (s, m, p, opts = veriOpts) => hashFinishS(_verify(s, m, p, opts)); +var etc = { + sha512Async: async (...messages) => { + const s = subtle(); + const m = concatBytes(...messages); + return u8n(await s.digest("SHA-512", m.buffer)); + }, + sha512Sync: void 0, + bytesToHex, + hexToBytes, + concatBytes, + mod: M, + invert, + randomBytes +}; +var utils = { + getExtendedPublicKeyAsync, + getExtendedPublicKey, + randomPrivateKey: () => randomBytes(L), + precompute: (w = 8, p = G) => { + p.multiply(3n); + w; + return p; + } + // no-op +}; +var W = 8; +var scalarBits = 256; +var pwindows = Math.ceil(scalarBits / W) + 1; +var pwindowSize = 2 ** (W - 1); +var precompute = () => { + const points = []; + let p = G; + let b = p; + for (let w = 0; w < pwindows; w++) { + b = p; + points.push(b); + for (let i = 1; i < pwindowSize; i++) { + b = b.add(p); + points.push(b); + } + p = b.double(); + } + return points; +}; +var Gpows = void 0; +var ctneg = (cnd, p) => { + const n = p.negate(); + return cnd ? n : p; +}; +var wNAF = (n) => { + const comp = Gpows || (Gpows = precompute()); + let p = I; + let f = G; + const pow_2_w = 2 ** W; + const maxNum = pow_2_w; + const mask = big(pow_2_w - 1); + const shiftBy = big(W); + for (let w = 0; w < pwindows; w++) { + let wbits = Number(n & mask); + n >>= shiftBy; + if (wbits > pwindowSize) { + wbits -= maxNum; + n += 1n; + } + const off = w * pwindowSize; + const offF = off; + const offP = off + Math.abs(wbits) - 1; + const isEven = w % 2 !== 0; + const isNeg = wbits < 0; + if (wbits === 0) { + f = f.add(ctneg(isEven, comp[offF])); + } else { + p = p.add(ctneg(isNeg, comp[offP])); + } + } + return { p, f }; +}; + +// src/browser/index.ts +var import_crypto_js2 = __toESM(require_crypto_js()); + +// src/types/enums.ts +var RouteType = /* @__PURE__ */ ((RouteType2) => { + RouteType2[RouteType2["TransportFlood"] = 0] = "TransportFlood"; + RouteType2[RouteType2["Flood"] = 1] = "Flood"; + RouteType2[RouteType2["Direct"] = 2] = "Direct"; + RouteType2[RouteType2["TransportDirect"] = 3] = "TransportDirect"; + return RouteType2; +})(RouteType || {}); +var PayloadType = /* @__PURE__ */ ((PayloadType2) => { + PayloadType2[PayloadType2["Request"] = 0] = "Request"; + PayloadType2[PayloadType2["Response"] = 1] = "Response"; + PayloadType2[PayloadType2["TextMessage"] = 2] = "TextMessage"; + PayloadType2[PayloadType2["Ack"] = 3] = "Ack"; + PayloadType2[PayloadType2["Advert"] = 4] = "Advert"; + PayloadType2[PayloadType2["GroupText"] = 5] = "GroupText"; + PayloadType2[PayloadType2["GroupData"] = 6] = "GroupData"; + PayloadType2[PayloadType2["AnonRequest"] = 7] = "AnonRequest"; + PayloadType2[PayloadType2["Path"] = 8] = "Path"; + PayloadType2[PayloadType2["Trace"] = 9] = "Trace"; + PayloadType2[PayloadType2["Multipart"] = 10] = "Multipart"; + PayloadType2[PayloadType2["Control"] = 11] = "Control"; + PayloadType2[PayloadType2["RawCustom"] = 15] = "RawCustom"; + return PayloadType2; +})(PayloadType || {}); +var ControlSubType = /* @__PURE__ */ ((ControlSubType2) => { + ControlSubType2[ControlSubType2["NodeDiscoverReq"] = 128] = "NodeDiscoverReq"; + ControlSubType2[ControlSubType2["NodeDiscoverResp"] = 144] = "NodeDiscoverResp"; + return ControlSubType2; +})(ControlSubType || {}); +var PayloadVersion = /* @__PURE__ */ ((PayloadVersion2) => { + PayloadVersion2[PayloadVersion2["Version1"] = 0] = "Version1"; + PayloadVersion2[PayloadVersion2["Version2"] = 1] = "Version2"; + PayloadVersion2[PayloadVersion2["Version3"] = 2] = "Version3"; + PayloadVersion2[PayloadVersion2["Version4"] = 3] = "Version4"; + return PayloadVersion2; +})(PayloadVersion || {}); +var DeviceRole = /* @__PURE__ */ ((DeviceRole2) => { + DeviceRole2[DeviceRole2["Unknown"] = 0] = "Unknown"; + DeviceRole2[DeviceRole2["ChatNode"] = 1] = "ChatNode"; + DeviceRole2[DeviceRole2["Repeater"] = 2] = "Repeater"; + DeviceRole2[DeviceRole2["RoomServer"] = 3] = "RoomServer"; + DeviceRole2[DeviceRole2["Sensor"] = 4] = "Sensor"; + return DeviceRole2; +})(DeviceRole || {}); +var AdvertFlags = /* @__PURE__ */ ((AdvertFlags2) => { + AdvertFlags2[AdvertFlags2["HasLocation"] = 16] = "HasLocation"; + AdvertFlags2[AdvertFlags2["HasFeature1"] = 32] = "HasFeature1"; + AdvertFlags2[AdvertFlags2["HasFeature2"] = 64] = "HasFeature2"; + AdvertFlags2[AdvertFlags2["HasName"] = 128] = "HasName"; + return AdvertFlags2; +})(AdvertFlags || {}); +var RequestType = /* @__PURE__ */ ((RequestType2) => { + RequestType2[RequestType2["GetStats"] = 1] = "GetStats"; + RequestType2[RequestType2["Keepalive"] = 2] = "Keepalive"; + RequestType2[RequestType2["GetTelemetryData"] = 3] = "GetTelemetryData"; + RequestType2[RequestType2["GetMinMaxAvgData"] = 4] = "GetMinMaxAvgData"; + RequestType2[RequestType2["GetAccessList"] = 5] = "GetAccessList"; + return RequestType2; +})(RequestType || {}); + +// src/crypto/channel-crypto.ts +var import_crypto_js = __toESM(require_crypto_js()); + +// src/utils/hex.ts +function byteToHex(byte) { + return byte.toString(16).padStart(2, "0").toUpperCase(); +} +function bytesToHex2(bytes) { + return Array.from(bytes).map(byteToHex).join(""); +} +function numberToHex(num, padLength = 8) { + return (num >>> 0).toString(16).padStart(padLength, "0").toUpperCase(); +} +function hexToBytes2(hex) { + const cleanHex = hex.replace(/\s/g, "").toUpperCase(); + if (!/^[0-9A-F]*$/.test(cleanHex)) { + throw new Error(`Invalid hex string: invalid characters at position 0`); + } + if (cleanHex.length % 2 !== 0) { + throw new Error("Invalid hex string: odd length"); + } + const bytes = new Uint8Array(cleanHex.length / 2); + for (let i = 0; i < cleanHex.length; i += 2) { + bytes[i / 2] = parseInt(cleanHex.substr(i, 2), 16); + } + return bytes; +} + +// src/crypto/channel-crypto.ts +var ChannelCrypto = class { + /** + * Decrypt GroupText message using MeshCore algorithm: + * - HMAC-SHA256 verification with 2-byte MAC + * - AES-128 ECB decryption + */ + static decryptGroupTextMessage(ciphertext, cipherMac, channelKey) { + try { + const channelKey16 = hexToBytes2(channelKey); + const macBytes = hexToBytes2(cipherMac); + const channelSecret = new Uint8Array(32); + channelSecret.set(channelKey16, 0); + const calculatedMac = (0, import_crypto_js.HmacSHA256)(import_crypto_js.enc.Hex.parse(ciphertext), import_crypto_js.enc.Hex.parse(bytesToHex2(channelSecret))); + const calculatedMacBytes = hexToBytes2(calculatedMac.toString(import_crypto_js.enc.Hex)); + const calculatedMacFirst2 = calculatedMacBytes.slice(0, 2); + if (calculatedMacFirst2[0] !== macBytes[0] || calculatedMacFirst2[1] !== macBytes[1]) { + return { success: false, error: "MAC verification failed" }; + } + const keyWords = import_crypto_js.enc.Hex.parse(channelKey); + const ciphertextWords = import_crypto_js.enc.Hex.parse(ciphertext); + const decrypted = import_crypto_js.AES.decrypt( + import_crypto_js.lib.CipherParams.create({ ciphertext: ciphertextWords }), + keyWords, + { mode: import_crypto_js.mode.ECB, padding: import_crypto_js.pad.NoPadding } + ); + const decryptedBytes = hexToBytes2(decrypted.toString(import_crypto_js.enc.Hex)); + if (!decryptedBytes || decryptedBytes.length < 5) { + return { success: false, error: "Decrypted content too short" }; + } + const timestamp = decryptedBytes[0] | decryptedBytes[1] << 8 | decryptedBytes[2] << 16 | decryptedBytes[3] << 24; + const flagsAndAttempt = decryptedBytes[4]; + const messageBytes = decryptedBytes.slice(5); + const decoder = new TextDecoder("utf-8"); + let messageText = decoder.decode(messageBytes); + const nullIndex = messageText.indexOf("\0"); + if (nullIndex >= 0) { + messageText = messageText.substring(0, nullIndex); + } + const colonIndex = messageText.indexOf(": "); + let sender; + let content; + if (colonIndex > 0 && colonIndex < 50) { + const potentialSender = messageText.substring(0, colonIndex); + if (!/[:\[\]]/.test(potentialSender)) { + sender = potentialSender; + content = messageText.substring(colonIndex + 2); + } else { + content = messageText; + } + } else { + content = messageText; + } + return { + success: true, + data: { + timestamp, + flags: flagsAndAttempt, + sender, + message: content + } + }; + } catch (error) { + return { success: false, error: error instanceof Error ? error.message : "Decryption failed" }; + } + } + /** + * Calculate MeshCore channel hash from secret key + * Returns the first byte of SHA256(secret) as hex string + */ + static calculateChannelHash(secretKeyHex) { + const hash = (0, import_crypto_js.SHA256)(import_crypto_js.enc.Hex.parse(secretKeyHex)); + const hashBytes = hexToBytes2(hash.toString(import_crypto_js.enc.Hex)); + return hashBytes[0].toString(16).padStart(2, "0"); + } +}; + +// src/crypto/key-manager.ts +var MeshCoreKeyStore = class { + constructor(initialKeys) { + this.nodeKeys = /* @__PURE__ */ new Map(); + // internal map for hash -> multiple keys (collision handling) + this.channelHashToKeys = /* @__PURE__ */ new Map(); + if (initialKeys?.channelSecrets) { + this.addChannelSecrets(initialKeys.channelSecrets); + } + if (initialKeys?.nodeKeys) { + Object.entries(initialKeys.nodeKeys).forEach(([pubKey, privKey]) => { + this.addNodeKey(pubKey, privKey); + }); + } + } + addNodeKey(publicKey, privateKey) { + const normalizedPubKey = publicKey.toUpperCase(); + this.nodeKeys.set(normalizedPubKey, privateKey); + } + hasChannelKey(channelHash) { + const normalizedHash = channelHash.toLowerCase(); + return this.channelHashToKeys.has(normalizedHash); + } + hasNodeKey(publicKey) { + const normalizedPubKey = publicKey.toUpperCase(); + return this.nodeKeys.has(normalizedPubKey); + } + /** + * Get all channel keys that match the given channel hash (handles collisions) + */ + getChannelKeys(channelHash) { + const normalizedHash = channelHash.toLowerCase(); + return this.channelHashToKeys.get(normalizedHash) || []; + } + getNodeKey(publicKey) { + const normalizedPubKey = publicKey.toUpperCase(); + return this.nodeKeys.get(normalizedPubKey); + } + /** + * Add channel keys by secret keys (new simplified API) + * Automatically calculates channel hashes + */ + addChannelSecrets(secretKeys) { + for (const secretKey of secretKeys) { + const channelHash = ChannelCrypto.calculateChannelHash(secretKey).toLowerCase(); + if (!this.channelHashToKeys.has(channelHash)) { + this.channelHashToKeys.set(channelHash, []); + } + this.channelHashToKeys.get(channelHash).push(secretKey); + } + } +}; + +// src/utils/enum-names.ts +function getRouteTypeName(routeType) { + switch (routeType) { + case 1 /* Flood */: + return "Flood"; + case 2 /* Direct */: + return "Direct"; + case 0 /* TransportFlood */: + return "TransportFlood"; + case 3 /* TransportDirect */: + return "TransportDirect"; + default: + return `Unknown (${routeType})`; + } +} +function getPayloadTypeName(payloadType) { + switch (payloadType) { + case 15 /* RawCustom */: + return "RawCustom"; + case 9 /* Trace */: + return "Trace"; + case 4 /* Advert */: + return "Advert"; + case 5 /* GroupText */: + return "GroupText"; + case 6 /* GroupData */: + return "GroupData"; + case 0 /* Request */: + return "Request"; + case 1 /* Response */: + return "Response"; + case 2 /* TextMessage */: + return "TextMessage"; + case 7 /* AnonRequest */: + return "AnonRequest"; + case 3 /* Ack */: + return "Ack"; + case 8 /* Path */: + return "Path"; + case 10 /* Multipart */: + return "Multipart"; + case 11 /* Control */: + return "Control"; + default: + return `Unknown (0x${payloadType.toString(16)})`; + } +} +function getPayloadVersionName(version) { + switch (version) { + case 0 /* Version1 */: + return "Version 1"; + case 1 /* Version2 */: + return "Version 2"; + case 2 /* Version3 */: + return "Version 3"; + case 3 /* Version4 */: + return "Version 4"; + default: + return `Unknown (${version})`; + } +} +function getDeviceRoleName(role) { + switch (role) { + case 0 /* Unknown */: + return "Unknown"; + case 1 /* ChatNode */: + return "Chat Node"; + case 2 /* Repeater */: + return "Repeater"; + case 3 /* RoomServer */: + return "Room Server"; + case 4 /* Sensor */: + return "Sensor"; + default: + return `Unknown (${role})`; + } +} +function getRequestTypeName(requestType) { + switch (requestType) { + case 1 /* GetStats */: + return "Get Stats"; + case 2 /* Keepalive */: + return "Keepalive (deprecated)"; + case 3 /* GetTelemetryData */: + return "Get Telemetry Data"; + case 4 /* GetMinMaxAvgData */: + return "Get Min/Max/Avg Data"; + case 5 /* GetAccessList */: + return "Get Access List"; + default: + return `Unknown (${requestType})`; + } +} +function getControlSubTypeName(subType) { + switch (subType) { + case 128 /* NodeDiscoverReq */: + return "Node Discover Request"; + case 144 /* NodeDiscoverResp */: + return "Node Discover Response"; + default: + return `Unknown (0x${subType.toString(16)})`; + } +} + +// src/crypto/orlp-ed25519-wasm.ts +var OrlpEd25519 = require_orlp_ed25519(); +async function getWasmInstance() { + return await OrlpEd25519(); +} +async function derivePublicKey(privateKeyHex) { + const wasmModule = await getWasmInstance(); + const privateKeyBytes = hexToBytes2(privateKeyHex); + if (privateKeyBytes.length !== 64) { + throw new Error(`Invalid private key length: expected 64 bytes, got ${privateKeyBytes.length}`); + } + const privateKeyPtr = 1024; + const publicKeyPtr = 1024 + 64; + wasmModule.HEAPU8.set(privateKeyBytes, privateKeyPtr); + const result = wasmModule.ccall( + "orlp_derive_public_key", + "number", + ["number", "number"], + [publicKeyPtr, privateKeyPtr] + ); + if (result !== 0) { + throw new Error("orlp key derivation failed: invalid private key"); + } + const publicKeyBytes = new Uint8Array(32); + publicKeyBytes.set(wasmModule.HEAPU8.subarray(publicKeyPtr, publicKeyPtr + 32)); + return bytesToHex2(publicKeyBytes); +} +async function validateKeyPair(privateKeyHex, expectedPublicKeyHex) { + try { + const wasmModule = await getWasmInstance(); + const privateKeyBytes = hexToBytes2(privateKeyHex); + const expectedPublicKeyBytes = hexToBytes2(expectedPublicKeyHex); + if (privateKeyBytes.length !== 64) { + return false; + } + if (expectedPublicKeyBytes.length !== 32) { + return false; + } + const privateKeyPtr = 2048; + const publicKeyPtr = 2048 + 64; + wasmModule.HEAPU8.set(privateKeyBytes, privateKeyPtr); + wasmModule.HEAPU8.set(expectedPublicKeyBytes, publicKeyPtr); + const result = wasmModule.ccall( + "orlp_validate_keypair", + "number", + ["number", "number"], + [publicKeyPtr, privateKeyPtr] + ); + return result === 1; + } catch (error) { + return false; + } +} + +// src/crypto/ed25519-verifier.ts +async function sha512Hash(data) { + if (typeof globalThis !== "undefined" && globalThis.crypto && globalThis.crypto.subtle) { + const hashBuffer = await globalThis.crypto.subtle.digest("SHA-512", data); + return new Uint8Array(hashBuffer); + } + if (typeof __require !== "undefined") { + try { + const { createHash } = require_crypto(); + return createHash("sha512").update(data).digest(); + } catch (error) { + } + } + throw new Error("No SHA-512 implementation available"); +} +function sha512HashSync(data) { + if (typeof __require !== "undefined") { + try { + const { createHash } = require_crypto(); + return createHash("sha512").update(data).digest(); + } catch (error) { + } + } + try { + const CryptoJS2 = require_crypto_js(); + const wordArray = CryptoJS2.lib.WordArray.create(data); + const hash = CryptoJS2.SHA512(wordArray); + const hashBytes = new Uint8Array(64); + for (let i = 0; i < 16; i++) { + const word = hash.words[i] || 0; + hashBytes[i * 4] = word >>> 24 & 255; + hashBytes[i * 4 + 1] = word >>> 16 & 255; + hashBytes[i * 4 + 2] = word >>> 8 & 255; + hashBytes[i * 4 + 3] = word & 255; + } + return hashBytes; + } catch (error) { + throw new Error("No SHA-512 implementation available for synchronous operation"); + } +} +etc.sha512Async = sha512Hash; +try { + etc.sha512Sync = sha512HashSync; +} catch (error) { + console.debug("Could not set up synchronous SHA-512:", error); +} +var Ed25519SignatureVerifier = class { + /** + * Verify an Ed25519 signature for MeshCore advertisement packets + * + * According to MeshCore protocol, the signed message for advertisements is: + * timestamp (4 bytes LE) + flags (1 byte) + location (8 bytes LE, if present) + name (variable, if present) + */ + static async verifyAdvertisementSignature(publicKeyHex, signatureHex, timestamp, appDataHex) { + try { + const publicKey = hexToBytes2(publicKeyHex); + const signature = hexToBytes2(signatureHex); + const appData = hexToBytes2(appDataHex); + const message = this.constructAdvertSignedMessage(publicKeyHex, timestamp, appData); + return await verify(signature, message, publicKey); + } catch (error) { + console.error("Ed25519 signature verification failed:", error); + return false; + } + } + /** + * Construct the signed message for MeshCore advertisements + * According to MeshCore source (Mesh.cpp lines 242-248): + * Format: public_key (32 bytes) + timestamp (4 bytes LE) + app_data (variable length) + */ + static constructAdvertSignedMessage(publicKeyHex, timestamp, appData) { + const publicKey = hexToBytes2(publicKeyHex); + const timestampBytes = new Uint8Array(4); + timestampBytes[0] = timestamp & 255; + timestampBytes[1] = timestamp >> 8 & 255; + timestampBytes[2] = timestamp >> 16 & 255; + timestampBytes[3] = timestamp >> 24 & 255; + const message = new Uint8Array(32 + 4 + appData.length); + message.set(publicKey, 0); + message.set(timestampBytes, 32); + message.set(appData, 36); + return message; + } + /** + * Get a human-readable description of what was signed + */ + static getSignedMessageDescription(publicKeyHex, timestamp, appDataHex) { + return `Public Key: ${publicKeyHex} + Timestamp: ${timestamp} (${new Date(timestamp * 1e3).toISOString()}) + App Data: ${appDataHex}`; + } + /** + * Get the hex representation of the signed message for debugging + */ + static getSignedMessageHex(publicKeyHex, timestamp, appDataHex) { + const appData = hexToBytes2(appDataHex); + const message = this.constructAdvertSignedMessage(publicKeyHex, timestamp, appData); + return bytesToHex2(message); + } + /** + * Derive Ed25519 public key from orlp/ed25519 private key format + * This implements the same algorithm as orlp/ed25519's ed25519_derive_pub() + * + * @param privateKeyHex - 64-byte private key in hex format (orlp/ed25519 format) + * @returns 32-byte public key in hex format + */ + static async derivePublicKey(privateKeyHex) { + try { + const privateKeyBytes = hexToBytes2(privateKeyHex); + if (privateKeyBytes.length !== 64) { + throw new Error(`Invalid private key length: expected 64 bytes, got ${privateKeyBytes.length}`); + } + return await derivePublicKey(privateKeyHex); + } catch (error) { + throw new Error(`Failed to derive public key: ${error instanceof Error ? error.message : "Unknown error"}`); + } + } + /** + * Derive Ed25519 public key from orlp/ed25519 private key format (synchronous version) + * This implements the same algorithm as orlp/ed25519's ed25519_derive_pub() + * + * @param privateKeyHex - 64-byte private key in hex format (orlp/ed25519 format) + * @returns 32-byte public key in hex format + */ + static derivePublicKeySync(privateKeyHex) { + try { + const privateKeyBytes = hexToBytes2(privateKeyHex); + if (privateKeyBytes.length !== 64) { + throw new Error(`Invalid private key length: expected 64 bytes, got ${privateKeyBytes.length}`); + } + throw new Error("Synchronous key derivation not supported with WASM. Use derivePublicKey() instead."); + } catch (error) { + throw new Error(`Failed to derive public key: ${error instanceof Error ? error.message : "Unknown error"}`); + } + } + /** + * Validate that a private key correctly derives to the expected public key + * + * @param privateKeyHex - 64-byte private key in hex format + * @param expectedPublicKeyHex - Expected 32-byte public key in hex format + * @returns true if the private key derives to the expected public key + */ + static async validateKeyPair(privateKeyHex, expectedPublicKeyHex) { + try { + return await validateKeyPair(privateKeyHex, expectedPublicKeyHex); + } catch (error) { + return false; + } + } +}; + +// src/decoder/payload-decoders/advert.ts +var AdvertPayloadDecoder = class { + static decode(payload, options) { + try { + if (payload.length < 101) { + const result = { + type: 4 /* Advert */, + version: 0 /* Version1 */, + isValid: false, + errors: ["Advertisement payload too short"], + publicKey: "", + timestamp: 0, + signature: "", + appData: { + flags: 0, + deviceRole: 1 /* ChatNode */, + hasLocation: false, + hasName: false + } + }; + if (options?.includeSegments) { + result.segments = [{ + name: "Invalid Advert Data", + description: "Advert payload too short (minimum 101 bytes required)", + startByte: options.segmentOffset || 0, + endByte: (options.segmentOffset || 0) + payload.length - 1, + value: bytesToHex2(payload) + }]; + } + return result; + } + const segments = []; + const segmentOffset = options?.segmentOffset || 0; + let currentOffset = 0; + const publicKey = bytesToHex2(payload.subarray(currentOffset, currentOffset + 32)); + if (options?.includeSegments) { + segments.push({ + name: "Public Key", + description: "Ed25519 public key", + startByte: segmentOffset + currentOffset, + endByte: segmentOffset + currentOffset + 31, + value: publicKey + }); + } + currentOffset += 32; + const timestamp = this.readUint32LE(payload, currentOffset); + if (options?.includeSegments) { + const timestampDate = new Date(timestamp * 1e3); + segments.push({ + name: "Timestamp", + description: `${timestamp} (${timestampDate.toISOString().slice(0, 19)}Z)`, + startByte: segmentOffset + currentOffset, + endByte: segmentOffset + currentOffset + 3, + value: bytesToHex2(payload.subarray(currentOffset, currentOffset + 4)) + }); + } + currentOffset += 4; + const signature = bytesToHex2(payload.subarray(currentOffset, currentOffset + 64)); + if (options?.includeSegments) { + segments.push({ + name: "Signature", + description: "Ed25519 signature", + startByte: segmentOffset + currentOffset, + endByte: segmentOffset + currentOffset + 63, + value: signature + }); + } + currentOffset += 64; + const flags = payload[currentOffset]; + if (options?.includeSegments) { + const binaryStr = flags.toString(2).padStart(8, "0"); + const deviceRole = this.parseDeviceRole(flags); + const roleName = getDeviceRoleName(deviceRole); + const flagDesc = ` | Bits 0-3 (Role): ${roleName} | Bit 4 (Location): ${!!(flags & 16 /* HasLocation */) ? "Yes" : "No"} | Bit 7 (Name): ${!!(flags & 128 /* HasName */) ? "Yes" : "No"}`; + segments.push({ + name: "App Flags", + description: `Binary: ${binaryStr}${flagDesc}`, + startByte: segmentOffset + currentOffset, + endByte: segmentOffset + currentOffset, + value: flags.toString(16).padStart(2, "0").toUpperCase() + }); + } + currentOffset += 1; + const advert = { + type: 4 /* Advert */, + version: 0 /* Version1 */, + isValid: true, + publicKey, + timestamp, + signature, + appData: { + flags, + deviceRole: this.parseDeviceRole(flags), + hasLocation: !!(flags & 16 /* HasLocation */), + hasName: !!(flags & 128 /* HasName */) + } + }; + let offset = currentOffset; + if (flags & 16 /* HasLocation */ && payload.length >= offset + 8) { + const lat = this.readInt32LE(payload, offset) / 1e6; + const lon = this.readInt32LE(payload, offset + 4) / 1e6; + advert.appData.location = { + latitude: Math.round(lat * 1e6) / 1e6, + // Keep precision + longitude: Math.round(lon * 1e6) / 1e6 + }; + if (options?.includeSegments) { + segments.push({ + name: "Latitude", + description: `${lat}\xB0 (${lat})`, + startByte: segmentOffset + offset, + endByte: segmentOffset + offset + 3, + value: bytesToHex2(payload.subarray(offset, offset + 4)) + }); + segments.push({ + name: "Longitude", + description: `${lon}\xB0 (${lon})`, + startByte: segmentOffset + offset + 4, + endByte: segmentOffset + offset + 7, + value: bytesToHex2(payload.subarray(offset + 4, offset + 8)) + }); + } + offset += 8; + } + if (flags & 32 /* HasFeature1 */) offset += 2; + if (flags & 64 /* HasFeature2 */) offset += 2; + if (flags & 128 /* HasName */ && payload.length > offset) { + const nameBytes = payload.subarray(offset); + const rawName = new TextDecoder("utf-8").decode(nameBytes).replace(/\0.*$/, ""); + advert.appData.name = this.sanitizeControlCharacters(rawName) || rawName; + if (options?.includeSegments) { + segments.push({ + name: "Node Name", + description: `Node name: "${advert.appData.name}"`, + startByte: segmentOffset + offset, + endByte: segmentOffset + payload.length - 1, + value: bytesToHex2(nameBytes) + }); + } + } + if (options?.includeSegments) { + advert.segments = segments; + } + return advert; + } catch (error) { + return { + type: 4 /* Advert */, + version: 0 /* Version1 */, + isValid: false, + errors: [error instanceof Error ? error.message : "Failed to decode advertisement payload"], + publicKey: "", + timestamp: 0, + signature: "", + appData: { + flags: 0, + deviceRole: 1 /* ChatNode */, + hasLocation: false, + hasName: false + } + }; + } + } + /** + * Decode advertisement payload with signature verification + */ + static async decodeWithVerification(payload, options) { + const advert = this.decode(payload, options); + if (!advert || !advert.isValid) { + return advert; + } + try { + const appDataStart = 32 + 4 + 64; + const appDataBytes = payload.subarray(appDataStart); + const appDataHex = bytesToHex2(appDataBytes); + const signatureValid = await Ed25519SignatureVerifier.verifyAdvertisementSignature( + advert.publicKey, + advert.signature, + advert.timestamp, + appDataHex + ); + advert.signatureValid = signatureValid; + if (!signatureValid) { + advert.signatureError = "Ed25519 signature verification failed"; + advert.isValid = false; + if (!advert.errors) { + advert.errors = []; + } + advert.errors.push("Invalid Ed25519 signature"); + } + } catch (error) { + advert.signatureValid = false; + advert.signatureError = error instanceof Error ? error.message : "Signature verification error"; + advert.isValid = false; + if (!advert.errors) { + advert.errors = []; + } + advert.errors.push("Signature verification failed: " + (error instanceof Error ? error.message : "Unknown error")); + } + return advert; + } + static parseDeviceRole(flags) { + const roleValue = flags & 15; + switch (roleValue) { + case 1: + return 1 /* ChatNode */; + case 2: + return 2 /* Repeater */; + case 3: + return 3 /* RoomServer */; + case 4: + return 4 /* Sensor */; + default: + return 1 /* ChatNode */; + } + } + static readUint32LE(buffer, offset) { + return buffer[offset] | buffer[offset + 1] << 8 | buffer[offset + 2] << 16 | buffer[offset + 3] << 24; + } + static readInt32LE(buffer, offset) { + const value = this.readUint32LE(buffer, offset); + return value > 2147483647 ? value - 4294967296 : value; + } + static sanitizeControlCharacters(value) { + if (!value) return null; + const sanitized = value.trim().replace(/[\x00-\x1F\x7F]/g, ""); + return sanitized || null; + } +}; + +// src/decoder/payload-decoders/trace.ts +var TracePayloadDecoder = class { + static decode(payload, pathData, options) { + try { + if (payload.length < 9) { + const result2 = { + type: 9 /* Trace */, + version: 0 /* Version1 */, + isValid: false, + errors: ["Trace payload too short (need at least tag(4) + auth(4) + flags(1))"], + traceTag: "00000000", + authCode: 0, + flags: 0, + pathHashes: [] + }; + if (options?.includeSegments) { + result2.segments = [{ + name: "Invalid Trace Data", + description: "Trace payload too short (minimum 9 bytes required)", + startByte: options.segmentOffset || 0, + endByte: (options.segmentOffset || 0) + payload.length - 1, + value: bytesToHex2(payload) + }]; + } + return result2; + } + let offset = 0; + const segments = []; + const segmentOffset = options?.segmentOffset || 0; + const traceTagRaw = this.readUint32LE(payload, offset); + const traceTag = numberToHex(traceTagRaw, 8); + if (options?.includeSegments) { + segments.push({ + name: "Trace Tag", + description: `Unique identifier for this trace: 0x${traceTagRaw.toString(16).padStart(8, "0")}`, + startByte: segmentOffset + offset, + endByte: segmentOffset + offset + 3, + value: bytesToHex2(payload.slice(offset, offset + 4)) + }); + } + offset += 4; + const authCode = this.readUint32LE(payload, offset); + if (options?.includeSegments) { + segments.push({ + name: "Auth Code", + description: `Authentication/verification code: ${authCode}`, + startByte: segmentOffset + offset, + endByte: segmentOffset + offset + 3, + value: bytesToHex2(payload.slice(offset, offset + 4)) + }); + } + offset += 4; + const flags = payload[offset]; + if (options?.includeSegments) { + segments.push({ + name: "Flags", + description: `Application-defined control flags: 0x${flags.toString(16).padStart(2, "0")} (${flags.toString(2).padStart(8, "0")}b)`, + startByte: segmentOffset + offset, + endByte: segmentOffset + offset, + value: flags.toString(16).padStart(2, "0").toUpperCase() + }); + } + offset += 1; + const pathHashes = []; + const pathHashesStart = offset; + while (offset < payload.length) { + pathHashes.push(byteToHex(payload[offset])); + offset++; + } + if (options?.includeSegments && pathHashes.length > 0) { + const pathHashesDisplay = pathHashes.join(" "); + segments.push({ + name: "Path Hashes", + description: `Node hashes in trace path: ${pathHashesDisplay}`, + startByte: segmentOffset + pathHashesStart, + endByte: segmentOffset + payload.length - 1, + value: bytesToHex2(payload.slice(pathHashesStart)) + }); + } + let snrValues; + if (pathData && pathData.length > 0) { + snrValues = pathData.map((hexByte) => { + const byteValue = parseInt(hexByte, 16); + const snrSigned = byteValue > 127 ? byteValue - 256 : byteValue; + return snrSigned / 4; + }); + } + const result = { + type: 9 /* Trace */, + version: 0 /* Version1 */, + isValid: true, + traceTag, + authCode, + flags, + pathHashes, + snrValues + }; + if (options?.includeSegments) { + result.segments = segments; + } + return result; + } catch (error) { + return { + type: 9 /* Trace */, + version: 0 /* Version1 */, + isValid: false, + errors: [error instanceof Error ? error.message : "Failed to decode trace payload"], + traceTag: "00000000", + authCode: 0, + flags: 0, + pathHashes: [] + }; + } + } + static readUint32LE(buffer, offset) { + return buffer[offset] | buffer[offset + 1] << 8 | buffer[offset + 2] << 16 | buffer[offset + 3] << 24; + } +}; + +// src/decoder/payload-decoders/group-text.ts +var GroupTextPayloadDecoder = class { + static decode(payload, options) { + try { + if (payload.length < 3) { + const result = { + type: 5 /* GroupText */, + version: 0 /* Version1 */, + isValid: false, + errors: ["GroupText payload too short (need at least channel_hash(1) + MAC(2))"], + channelHash: "", + cipherMac: "", + ciphertext: "", + ciphertextLength: 0 + }; + if (options?.includeSegments) { + result.segments = [{ + name: "Invalid GroupText Data", + description: "GroupText payload too short (minimum 3 bytes required)", + startByte: options.segmentOffset || 0, + endByte: (options.segmentOffset || 0) + payload.length - 1, + value: bytesToHex2(payload) + }]; + } + return result; + } + const segments = []; + const segmentOffset = options?.segmentOffset || 0; + let offset = 0; + const channelHash = byteToHex(payload[offset]); + if (options?.includeSegments) { + segments.push({ + name: "Channel Hash", + description: "First byte of SHA256 of channel's shared key", + startByte: segmentOffset + offset, + endByte: segmentOffset + offset, + value: channelHash + }); + } + offset += 1; + const cipherMac = bytesToHex2(payload.subarray(offset, offset + 2)); + if (options?.includeSegments) { + segments.push({ + name: "Cipher MAC", + description: "MAC for encrypted data", + startByte: segmentOffset + offset, + endByte: segmentOffset + offset + 1, + value: cipherMac + }); + } + offset += 2; + const ciphertext = bytesToHex2(payload.subarray(offset)); + if (options?.includeSegments && payload.length > offset) { + segments.push({ + name: "Ciphertext", + description: "Encrypted message content (timestamp + flags + message)", + startByte: segmentOffset + offset, + endByte: segmentOffset + payload.length - 1, + value: ciphertext + }); + } + const groupText = { + type: 5 /* GroupText */, + version: 0 /* Version1 */, + isValid: true, + channelHash, + cipherMac, + ciphertext, + ciphertextLength: payload.length - 3 + }; + if (options?.keyStore && options.keyStore.hasChannelKey(channelHash)) { + const channelKeys = options.keyStore.getChannelKeys(channelHash); + for (const channelKey of channelKeys) { + const decryptionResult = ChannelCrypto.decryptGroupTextMessage( + ciphertext, + cipherMac, + channelKey + ); + if (decryptionResult.success && decryptionResult.data) { + groupText.decrypted = { + timestamp: decryptionResult.data.timestamp, + flags: decryptionResult.data.flags, + sender: decryptionResult.data.sender, + message: decryptionResult.data.message + }; + break; + } + } + } + if (options?.includeSegments) { + groupText.segments = segments; + } + return groupText; + } catch (error) { + return { + type: 5 /* GroupText */, + version: 0 /* Version1 */, + isValid: false, + errors: [error instanceof Error ? error.message : "Failed to decode GroupText payload"], + channelHash: "", + cipherMac: "", + ciphertext: "", + ciphertextLength: 0 + }; + } + } +}; + +// src/decoder/payload-decoders/request.ts +var RequestPayloadDecoder = class { + static decode(payload, options) { + try { + if (payload.length < 4) { + const result2 = { + type: 0 /* Request */, + version: 0 /* Version1 */, + isValid: false, + errors: ["Request payload too short (minimum 4 bytes: dest hash + source hash + MAC)"], + timestamp: 0, + requestType: 1 /* GetStats */, + requestData: "", + destinationHash: "", + sourceHash: "", + cipherMac: "", + ciphertext: "" + }; + if (options?.includeSegments) { + result2.segments = [{ + name: "Invalid Request Data", + description: "Request payload too short (minimum 4 bytes required: 1 for dest hash + 1 for source hash + 2 for MAC)", + startByte: options.segmentOffset || 0, + endByte: (options.segmentOffset || 0) + payload.length - 1, + value: bytesToHex2(payload) + }]; + } + return result2; + } + const segments = []; + const segmentOffset = options?.segmentOffset || 0; + let offset = 0; + const destinationHash = bytesToHex2(payload.subarray(offset, offset + 1)); + if (options?.includeSegments) { + segments.push({ + name: "Destination Hash", + description: `First byte of destination node public key: 0x${destinationHash}`, + startByte: segmentOffset + offset, + endByte: segmentOffset + offset, + value: destinationHash + }); + } + offset += 1; + const sourceHash = bytesToHex2(payload.subarray(offset, offset + 1)); + if (options?.includeSegments) { + segments.push({ + name: "Source Hash", + description: `First byte of source node public key: 0x${sourceHash}`, + startByte: segmentOffset + offset, + endByte: segmentOffset + offset, + value: sourceHash + }); + } + offset += 1; + const cipherMac = bytesToHex2(payload.subarray(offset, offset + 2)); + if (options?.includeSegments) { + segments.push({ + name: "Cipher MAC", + description: `MAC for encrypted data verification (2 bytes)`, + startByte: segmentOffset + offset, + endByte: segmentOffset + offset + 1, + value: cipherMac + }); + } + offset += 2; + const ciphertext = bytesToHex2(payload.subarray(offset)); + if (options?.includeSegments && payload.length > offset) { + segments.push({ + name: "Ciphertext", + description: `Encrypted message data (${payload.length - offset} bytes). Contains encrypted plaintext with this structure: +\u2022 Timestamp (4 bytes) - send time as unix timestamp +\u2022 Request Type (1 byte) - type of request (GetStats, GetTelemetryData, etc.) +\u2022 Request Data (remaining bytes) - additional request-specific data`, + startByte: segmentOffset + offset, + endByte: segmentOffset + payload.length - 1, + value: ciphertext + }); + } + const result = { + type: 0 /* Request */, + version: 0 /* Version1 */, + isValid: true, + timestamp: 0, + // Encrypted, cannot be parsed without decryption + requestType: 1 /* GetStats */, + // Encrypted, cannot be determined without decryption + requestData: "", + destinationHash, + sourceHash, + cipherMac, + ciphertext + }; + if (options?.includeSegments) { + result.segments = segments; + } + return result; + } catch (error) { + return { + type: 0 /* Request */, + version: 0 /* Version1 */, + isValid: false, + errors: [error instanceof Error ? error.message : "Failed to decode request payload"], + timestamp: 0, + requestType: 1 /* GetStats */, + requestData: "", + destinationHash: "", + sourceHash: "", + cipherMac: "", + ciphertext: "" + }; + } + } +}; + +// src/decoder/payload-decoders/response.ts +var ResponsePayloadDecoder = class { + static decode(payload, options) { + try { + if (payload.length < 4) { + const result2 = { + type: 1 /* Response */, + version: 0 /* Version1 */, + isValid: false, + errors: ["Response payload too short (minimum 4 bytes: dest + source + MAC)"], + destinationHash: "", + sourceHash: "", + cipherMac: "", + ciphertext: "", + ciphertextLength: 0 + }; + if (options?.includeSegments) { + result2.segments = [{ + name: "Invalid Response Data", + description: "Response payload too short (minimum 4 bytes required)", + startByte: options.segmentOffset || 0, + endByte: (options.segmentOffset || 0) + payload.length - 1, + value: bytesToHex2(payload) + }]; + } + return result2; + } + const segments = []; + const segmentOffset = options?.segmentOffset || 0; + let offset = 0; + const destinationHash = byteToHex(payload[offset]); + if (options?.includeSegments) { + segments.push({ + name: "Destination Hash", + description: "First byte of destination node public key", + startByte: segmentOffset + offset, + endByte: segmentOffset + offset, + value: destinationHash + }); + } + offset += 1; + const sourceHash = byteToHex(payload[offset]); + if (options?.includeSegments) { + segments.push({ + name: "Source Hash", + description: "First byte of source node public key", + startByte: segmentOffset + offset, + endByte: segmentOffset + offset, + value: sourceHash + }); + } + offset += 1; + const cipherMac = bytesToHex2(payload.subarray(offset, offset + 2)); + if (options?.includeSegments) { + segments.push({ + name: "Cipher MAC", + description: "MAC for encrypted data in next field", + startByte: segmentOffset + offset, + endByte: segmentOffset + offset + 1, + value: cipherMac + }); + } + offset += 2; + const ciphertext = bytesToHex2(payload.subarray(offset)); + if (options?.includeSegments && payload.length > offset) { + segments.push({ + name: "Ciphertext", + description: "Encrypted response data (tag + content)", + startByte: segmentOffset + offset, + endByte: segmentOffset + payload.length - 1, + value: ciphertext + }); + } + const result = { + type: 1 /* Response */, + version: 0 /* Version1 */, + isValid: true, + destinationHash, + sourceHash, + cipherMac, + ciphertext, + ciphertextLength: payload.length - 4 + }; + if (options?.includeSegments) { + result.segments = segments; + } + return result; + } catch (error) { + return { + type: 1 /* Response */, + version: 0 /* Version1 */, + isValid: false, + errors: [error instanceof Error ? error.message : "Failed to decode response payload"], + destinationHash: "", + sourceHash: "", + cipherMac: "", + ciphertext: "", + ciphertextLength: 0 + }; + } + } +}; + +// src/decoder/payload-decoders/anon-request.ts +var AnonRequestPayloadDecoder = class { + static decode(payload, options) { + try { + if (payload.length < 35) { + const result2 = { + type: 7 /* AnonRequest */, + version: 0 /* Version1 */, + isValid: false, + errors: ["AnonRequest payload too short (minimum 35 bytes: dest + public key + MAC)"], + destinationHash: "", + senderPublicKey: "", + cipherMac: "", + ciphertext: "", + ciphertextLength: 0 + }; + if (options?.includeSegments) { + result2.segments = [{ + name: "Invalid AnonRequest Data", + description: "AnonRequest payload too short (minimum 35 bytes required: 1 for dest hash + 32 for public key + 2 for MAC)", + startByte: options.segmentOffset || 0, + endByte: (options.segmentOffset || 0) + payload.length - 1, + value: bytesToHex2(payload) + }]; + } + return result2; + } + const segments = []; + const segmentOffset = options?.segmentOffset || 0; + let offset = 0; + const destinationHash = byteToHex(payload[0]); + if (options?.includeSegments) { + segments.push({ + name: "Destination Hash", + description: `First byte of destination node public key: 0x${destinationHash}`, + startByte: segmentOffset + offset, + endByte: segmentOffset + offset, + value: destinationHash + }); + } + offset += 1; + const senderPublicKey = bytesToHex2(payload.subarray(1, 33)); + if (options?.includeSegments) { + segments.push({ + name: "Sender Public Key", + description: `Ed25519 public key of the sender (32 bytes)`, + startByte: segmentOffset + offset, + endByte: segmentOffset + offset + 31, + value: senderPublicKey + }); + } + offset += 32; + const cipherMac = bytesToHex2(payload.subarray(33, 35)); + if (options?.includeSegments) { + segments.push({ + name: "Cipher MAC", + description: `MAC for encrypted data verification (2 bytes)`, + startByte: segmentOffset + offset, + endByte: segmentOffset + offset + 1, + value: cipherMac + }); + } + offset += 2; + const ciphertext = bytesToHex2(payload.subarray(35)); + if (options?.includeSegments && payload.length > 35) { + segments.push({ + name: "Ciphertext", + description: `Encrypted message data (${payload.length - 35} bytes). Contains encrypted plaintext with this structure: +\u2022 Timestamp (4 bytes) - send time as unix timestamp +\u2022 Sync Timestamp (4 bytes) - room server only, sender's "sync messages SINCE x" timestamp +\u2022 Password (remaining bytes) - password for repeater/room`, + startByte: segmentOffset + offset, + endByte: segmentOffset + payload.length - 1, + value: ciphertext + }); + } + const result = { + type: 7 /* AnonRequest */, + version: 0 /* Version1 */, + isValid: true, + destinationHash, + senderPublicKey, + cipherMac, + ciphertext, + ciphertextLength: payload.length - 35 + }; + if (options?.includeSegments) { + result.segments = segments; + } + return result; + } catch (error) { + return { + type: 7 /* AnonRequest */, + version: 0 /* Version1 */, + isValid: false, + errors: [error instanceof Error ? error.message : "Failed to decode AnonRequest payload"], + destinationHash: "", + senderPublicKey: "", + cipherMac: "", + ciphertext: "", + ciphertextLength: 0 + }; + } + } +}; + +// src/decoder/payload-decoders/ack.ts +var AckPayloadDecoder = class { + static decode(payload, options) { + try { + if (payload.length < 4) { + const result2 = { + type: 3 /* Ack */, + version: 0 /* Version1 */, + isValid: false, + errors: ["Ack payload too short (minimum 4 bytes for checksum)"], + checksum: "" + }; + if (options?.includeSegments) { + result2.segments = [{ + name: "Invalid Ack Data", + description: "Ack payload too short (minimum 4 bytes required for checksum)", + startByte: options.segmentOffset || 0, + endByte: (options.segmentOffset || 0) + payload.length - 1, + value: bytesToHex2(payload) + }]; + } + return result2; + } + const segments = []; + const segmentOffset = options?.segmentOffset || 0; + const checksum = bytesToHex2(payload.subarray(0, 4)); + if (options?.includeSegments) { + segments.push({ + name: "Checksum", + description: `CRC checksum of message timestamp, text, and sender pubkey: 0x${checksum}`, + startByte: segmentOffset, + endByte: segmentOffset + 3, + value: checksum + }); + } + if (options?.includeSegments && payload.length > 4) { + segments.push({ + name: "Additional Data", + description: "Extra data in Ack payload", + startByte: segmentOffset + 4, + endByte: segmentOffset + payload.length - 1, + value: bytesToHex2(payload.subarray(4)) + }); + } + const result = { + type: 3 /* Ack */, + version: 0 /* Version1 */, + isValid: true, + checksum + }; + if (options?.includeSegments) { + result.segments = segments; + } + return result; + } catch (error) { + return { + type: 3 /* Ack */, + version: 0 /* Version1 */, + isValid: false, + errors: [error instanceof Error ? error.message : "Failed to decode Ack payload"], + checksum: "" + }; + } + } +}; + +// src/decoder/payload-decoders/path.ts +var PathPayloadDecoder = class { + static decode(payload) { + try { + if (payload.length < 2) { + return { + type: 8 /* Path */, + version: 0 /* Version1 */, + isValid: false, + errors: ["Path payload too short (minimum 2 bytes: path length + extra type)"], + pathLength: 0, + pathHashes: [], + extraType: 0, + extraData: "" + }; + } + const pathLength = payload[0]; + if (payload.length < 1 + pathLength + 1) { + return { + type: 8 /* Path */, + version: 0 /* Version1 */, + isValid: false, + errors: [`Path payload too short (need ${1 + pathLength + 1} bytes for path length + path + extra type)`], + pathLength, + pathHashes: [], + extraType: 0, + extraData: "" + }; + } + const pathHashes = []; + for (let i = 0; i < pathLength; i++) { + pathHashes.push(byteToHex(payload[1 + i])); + } + const extraType = payload[1 + pathLength]; + let extraData = ""; + if (payload.length > 1 + pathLength + 1) { + extraData = bytesToHex2(payload.subarray(1 + pathLength + 1)); + } + return { + type: 8 /* Path */, + version: 0 /* Version1 */, + isValid: true, + pathLength, + pathHashes, + extraType, + extraData + }; + } catch (error) { + return { + type: 8 /* Path */, + version: 0 /* Version1 */, + isValid: false, + errors: [error instanceof Error ? error.message : "Failed to decode Path payload"], + pathLength: 0, + pathHashes: [], + extraType: 0, + extraData: "" + }; + } + } +}; + +// src/decoder/payload-decoders/text-message.ts +var TextMessagePayloadDecoder = class { + static decode(payload, options) { + try { + if (payload.length < 4) { + const result2 = { + type: 2 /* TextMessage */, + version: 0 /* Version1 */, + isValid: false, + errors: ["TextMessage payload too short (minimum 4 bytes: dest + source + MAC)"], + destinationHash: "", + sourceHash: "", + cipherMac: "", + ciphertext: "", + ciphertextLength: 0 + }; + if (options?.includeSegments) { + result2.segments = [{ + name: "Invalid TextMessage Data", + description: "TextMessage payload too short (minimum 4 bytes required)", + startByte: options.segmentOffset || 0, + endByte: (options.segmentOffset || 0) + payload.length - 1, + value: bytesToHex2(payload) + }]; + } + return result2; + } + const segments = []; + const segmentOffset = options?.segmentOffset || 0; + let offset = 0; + const destinationHash = byteToHex(payload[offset]); + if (options?.includeSegments) { + segments.push({ + name: "Destination Hash", + description: "First byte of destination node public key", + startByte: segmentOffset + offset, + endByte: segmentOffset + offset, + value: destinationHash + }); + } + offset += 1; + const sourceHash = byteToHex(payload[offset]); + if (options?.includeSegments) { + segments.push({ + name: "Source Hash", + description: "First byte of source node public key", + startByte: segmentOffset + offset, + endByte: segmentOffset + offset, + value: sourceHash + }); + } + offset += 1; + const cipherMac = bytesToHex2(payload.subarray(offset, offset + 2)); + if (options?.includeSegments) { + segments.push({ + name: "Cipher MAC", + description: "MAC for encrypted data in next field", + startByte: segmentOffset + offset, + endByte: segmentOffset + offset + 1, + value: cipherMac + }); + } + offset += 2; + const ciphertext = bytesToHex2(payload.subarray(offset)); + if (options?.includeSegments && payload.length > offset) { + segments.push({ + name: "Ciphertext", + description: "Encrypted message data (timestamp + message text)", + startByte: segmentOffset + offset, + endByte: segmentOffset + payload.length - 1, + value: ciphertext + }); + } + const result = { + type: 2 /* TextMessage */, + version: 0 /* Version1 */, + isValid: true, + destinationHash, + sourceHash, + cipherMac, + ciphertext, + ciphertextLength: payload.length - 4 + }; + if (options?.includeSegments) { + result.segments = segments; + } + return result; + } catch (error) { + return { + type: 2 /* TextMessage */, + version: 0 /* Version1 */, + isValid: false, + errors: [error instanceof Error ? error.message : "Failed to decode TextMessage payload"], + destinationHash: "", + sourceHash: "", + cipherMac: "", + ciphertext: "", + ciphertextLength: 0 + }; + } + } +}; + +// src/decoder/payload-decoders/control.ts +var ControlPayloadDecoder = class { + static decode(payload, options) { + try { + if (payload.length < 1) { + return this.createErrorPayload("Control payload too short (minimum 1 byte required)", payload, options); + } + const rawFlags = payload[0]; + const subType = rawFlags & 240; + switch (subType) { + case 128 /* NodeDiscoverReq */: + return this.decodeDiscoverReq(payload, options); + case 144 /* NodeDiscoverResp */: + return this.decodeDiscoverResp(payload, options); + default: + return this.createErrorPayload(`Unknown control sub-type: 0x${subType.toString(16).padStart(2, "0")}`, payload, options); + } + } catch (error) { + return this.createErrorPayload(error instanceof Error ? error.message : "Failed to decode control payload", payload, options); + } + } + static decodeDiscoverReq(payload, options) { + const segments = []; + const segmentOffset = options?.segmentOffset ?? 0; + if (payload.length < 6) { + const result2 = { + type: 11 /* Control */, + version: 0 /* Version1 */, + isValid: false, + errors: ["DISCOVER_REQ payload too short (minimum 6 bytes required)"], + subType: 128 /* NodeDiscoverReq */, + rawFlags: payload[0], + prefixOnly: false, + typeFilter: 0, + typeFilterNames: [], + tag: 0, + since: 0 + }; + if (options?.includeSegments) { + result2.segments = [{ + name: "Invalid DISCOVER_REQ Data", + description: "DISCOVER_REQ payload too short (minimum 6 bytes required)", + startByte: segmentOffset, + endByte: segmentOffset + payload.length - 1, + value: bytesToHex2(payload) + }]; + } + return result2; + } + let offset = 0; + const rawFlags = payload[offset]; + const prefixOnly = (rawFlags & 1) !== 0; + if (options?.includeSegments) { + segments.push({ + name: "Flags", + description: `Sub-type: DISCOVER_REQ (0x8) | Prefix Only: ${prefixOnly}`, + startByte: segmentOffset + offset, + endByte: segmentOffset + offset, + value: rawFlags.toString(16).padStart(2, "0").toUpperCase() + }); + } + offset += 1; + const typeFilter = payload[offset]; + const typeFilterNames = this.parseTypeFilter(typeFilter); + if (options?.includeSegments) { + segments.push({ + name: "Type Filter", + description: `Filter mask: 0b${typeFilter.toString(2).padStart(8, "0")} | Types: ${typeFilterNames.length > 0 ? typeFilterNames.join(", ") : "None"}`, + startByte: segmentOffset + offset, + endByte: segmentOffset + offset, + value: typeFilter.toString(16).padStart(2, "0").toUpperCase() + }); + } + offset += 1; + const tag = this.readUint32LE(payload, offset); + if (options?.includeSegments) { + segments.push({ + name: "Tag", + description: `Random tag for response matching: 0x${tag.toString(16).padStart(8, "0")}`, + startByte: segmentOffset + offset, + endByte: segmentOffset + offset + 3, + value: bytesToHex2(payload.slice(offset, offset + 4)) + }); + } + offset += 4; + let since = 0; + if (payload.length >= offset + 4) { + since = this.readUint32LE(payload, offset); + if (options?.includeSegments) { + const sinceDate = since > 0 ? new Date(since * 1e3).toISOString().slice(0, 19) + "Z" : "N/A"; + segments.push({ + name: "Since", + description: `Filter timestamp: ${since} (${sinceDate})`, + startByte: segmentOffset + offset, + endByte: segmentOffset + offset + 3, + value: bytesToHex2(payload.slice(offset, offset + 4)) + }); + } + } + const result = { + type: 11 /* Control */, + version: 0 /* Version1 */, + isValid: true, + subType: 128 /* NodeDiscoverReq */, + rawFlags, + prefixOnly, + typeFilter, + typeFilterNames, + tag, + since + }; + if (options?.includeSegments) { + result.segments = segments; + } + return result; + } + static decodeDiscoverResp(payload, options) { + const segments = []; + const segmentOffset = options?.segmentOffset ?? 0; + if (payload.length < 14) { + const result2 = { + type: 11 /* Control */, + version: 0 /* Version1 */, + isValid: false, + errors: ["DISCOVER_RESP payload too short (minimum 14 bytes required)"], + subType: 144 /* NodeDiscoverResp */, + rawFlags: payload.length > 0 ? payload[0] : 0, + nodeType: 0 /* Unknown */, + nodeTypeName: "Unknown", + snr: 0, + tag: 0, + publicKey: "", + publicKeyLength: 0 + }; + if (options?.includeSegments) { + result2.segments = [{ + name: "Invalid DISCOVER_RESP Data", + description: "DISCOVER_RESP payload too short (minimum 14 bytes required)", + startByte: segmentOffset, + endByte: segmentOffset + payload.length - 1, + value: bytesToHex2(payload) + }]; + } + return result2; + } + let offset = 0; + const rawFlags = payload[offset]; + const nodeType = rawFlags & 15; + const nodeTypeName = getDeviceRoleName(nodeType); + if (options?.includeSegments) { + segments.push({ + name: "Flags", + description: `Sub-type: DISCOVER_RESP (0x9) | Node Type: ${nodeTypeName}`, + startByte: segmentOffset + offset, + endByte: segmentOffset + offset, + value: rawFlags.toString(16).padStart(2, "0").toUpperCase() + }); + } + offset += 1; + const snrRaw = payload[offset]; + const snrSigned = snrRaw > 127 ? snrRaw - 256 : snrRaw; + const snr = snrSigned / 4; + if (options?.includeSegments) { + segments.push({ + name: "SNR", + description: `Inbound SNR: ${snr.toFixed(2)} dB (raw: ${snrRaw}, signed: ${snrSigned})`, + startByte: segmentOffset + offset, + endByte: segmentOffset + offset, + value: snrRaw.toString(16).padStart(2, "0").toUpperCase() + }); + } + offset += 1; + const tag = this.readUint32LE(payload, offset); + if (options?.includeSegments) { + segments.push({ + name: "Tag", + description: `Reflected tag from request: 0x${tag.toString(16).padStart(8, "0")}`, + startByte: segmentOffset + offset, + endByte: segmentOffset + offset + 3, + value: bytesToHex2(payload.slice(offset, offset + 4)) + }); + } + offset += 4; + const remainingBytes = payload.length - offset; + const publicKeyLength = remainingBytes; + const publicKeyBytes = payload.slice(offset, offset + publicKeyLength); + const publicKey = bytesToHex2(publicKeyBytes); + if (options?.includeSegments) { + const keyType = publicKeyLength === 32 ? "Full Public Key" : "Public Key Prefix"; + segments.push({ + name: keyType, + description: `${keyType} (${publicKeyLength} bytes)`, + startByte: segmentOffset + offset, + endByte: segmentOffset + offset + publicKeyLength - 1, + value: publicKey + }); + } + const result = { + type: 11 /* Control */, + version: 0 /* Version1 */, + isValid: true, + subType: 144 /* NodeDiscoverResp */, + rawFlags, + nodeType, + nodeTypeName, + snr, + tag, + publicKey, + publicKeyLength + }; + if (options?.includeSegments) { + result.segments = segments; + } + return result; + } + static parseTypeFilter(filter) { + const types = []; + if (filter & 1 << 1 /* ChatNode */) types.push("Chat"); + if (filter & 1 << 2 /* Repeater */) types.push("Repeater"); + if (filter & 1 << 3 /* RoomServer */) types.push("Room"); + if (filter & 1 << 4 /* Sensor */) types.push("Sensor"); + return types; + } + static createErrorPayload(error, payload, options) { + const result = { + type: 11 /* Control */, + version: 0 /* Version1 */, + isValid: false, + errors: [error], + subType: 128 /* NodeDiscoverReq */, + rawFlags: payload.length > 0 ? payload[0] : 0, + prefixOnly: false, + typeFilter: 0, + typeFilterNames: [], + tag: 0, + since: 0 + }; + if (options?.includeSegments) { + result.segments = [{ + name: "Invalid Control Data", + description: error, + startByte: options.segmentOffset ?? 0, + endByte: (options.segmentOffset ?? 0) + payload.length - 1, + value: bytesToHex2(payload) + }]; + } + return result; + } + static readUint32LE(buffer, offset) { + return (buffer[offset] | buffer[offset + 1] << 8 | buffer[offset + 2] << 16 | buffer[offset + 3] << 24) >>> 0; + } +}; + +// src/decoder/packet-decoder.ts +var MeshCorePacketDecoder = class { + /** + * Decode a raw packet from hex string + */ + static decode(hexData, options) { + const result = this.parseInternal(hexData, false, options); + return result.packet; + } + /** + * Decode a raw packet from hex string with signature verification for advertisements + */ + static async decodeWithVerification(hexData, options) { + const result = await this.parseInternalAsync(hexData, false, options); + return result.packet; + } + /** + * Analyze packet structure for detailed breakdown + */ + static analyzeStructure(hexData, options) { + const result = this.parseInternal(hexData, true, options); + return result.structure; + } + /** + * Analyze packet structure for detailed breakdown with signature verification for advertisements + */ + static async analyzeStructureWithVerification(hexData, options) { + const result = await this.parseInternalAsync(hexData, true, options); + return result.structure; + } + /** + * Internal unified parsing method + */ + static parseInternal(hexData, includeStructure, options) { + const bytes = hexToBytes2(hexData); + const segments = []; + if (bytes.length < 2) { + const errorPacket = { + messageHash: "", + routeType: 1 /* Flood */, + payloadType: 15 /* RawCustom */, + payloadVersion: 0 /* Version1 */, + pathLength: 0, + path: null, + payload: { raw: "", decoded: null }, + totalBytes: bytes.length, + isValid: false, + errors: ["Packet too short (minimum 2 bytes required)"] + }; + const errorStructure = { + segments: [], + totalBytes: bytes.length, + rawHex: hexData.toUpperCase(), + messageHash: "", + payload: { + segments: [], + hex: "", + startByte: 0, + type: "Unknown" + } + }; + return { packet: errorPacket, structure: errorStructure }; + } + try { + let offset = 0; + const header = bytes[0]; + const routeType = header & 3; + const payloadType = header >> 2 & 15; + const payloadVersion = header >> 6 & 3; + if (includeStructure) { + segments.push({ + name: "Header", + description: "Header byte breakdown", + startByte: 0, + endByte: 0, + value: `0x${header.toString(16).padStart(2, "0")}`, + headerBreakdown: { + fullBinary: header.toString(2).padStart(8, "0"), + fields: [ + { + bits: "0-1", + field: "Route Type", + value: getRouteTypeName(routeType), + binary: (header & 3).toString(2).padStart(2, "0") + }, + { + bits: "2-5", + field: "Payload Type", + value: getPayloadTypeName(payloadType), + binary: (header >> 2 & 15).toString(2).padStart(4, "0") + }, + { + bits: "6-7", + field: "Version", + value: payloadVersion.toString(), + binary: (header >> 6 & 3).toString(2).padStart(2, "0") + } + ] + } + }); + } + offset = 1; + let transportCodes; + if (routeType === 0 /* TransportFlood */ || routeType === 3 /* TransportDirect */) { + if (bytes.length < offset + 4) { + throw new Error("Packet too short for transport codes"); + } + const code1 = bytes[offset] | bytes[offset + 1] << 8; + const code2 = bytes[offset + 2] | bytes[offset + 3] << 8; + transportCodes = [code1, code2]; + if (includeStructure) { + const transportCode = bytes[offset] | bytes[offset + 1] << 8 | bytes[offset + 2] << 16 | bytes[offset + 3] << 24; + segments.push({ + name: "Transport Code", + description: "Used for Direct/Response routing", + startByte: offset, + endByte: offset + 3, + value: `0x${transportCode.toString(16).padStart(8, "0")}` + }); + } + offset += 4; + } + if (bytes.length < offset + 1) { + throw new Error("Packet too short for path length"); + } + const pathLength = bytes[offset]; + if (includeStructure) { + let pathLengthDescription = `Path contains ${pathLength} bytes`; + if (routeType === 2 /* Direct */ || routeType === 3 /* TransportDirect */) { + pathLengthDescription = `For "Direct" packets, this contains routing instructions. ${pathLength} bytes of routing instructions (decreases as packet travels)`; + } else if (routeType === 1 /* Flood */ || routeType === 0 /* TransportFlood */) { + pathLengthDescription = `${pathLength} bytes showing route taken (increases as packet floods)`; + } + segments.push({ + name: "Path Length", + description: pathLengthDescription, + startByte: offset, + endByte: offset, + value: `0x${pathLength.toString(16).padStart(2, "0")}` + }); + } + offset += 1; + if (bytes.length < offset + pathLength) { + throw new Error("Packet too short for path data"); + } + const pathBytes = bytes.subarray(offset, offset + pathLength); + const path = pathLength > 0 ? Array.from(pathBytes).map(byteToHex) : null; + if (includeStructure && pathLength > 0) { + if (payloadType === 9 /* Trace */) { + const snrValues = []; + for (let i = 0; i < pathLength; i++) { + const snrRaw = bytes[offset + i]; + const snrSigned = snrRaw > 127 ? snrRaw - 256 : snrRaw; + const snrDb = snrSigned / 4; + snrValues.push(`${snrDb.toFixed(2)}dB (0x${snrRaw.toString(16).padStart(2, "0")})`); + } + segments.push({ + name: "Path SNR Data", + description: `SNR values collected during trace: ${snrValues.join(", ")}`, + startByte: offset, + endByte: offset + pathLength - 1, + value: bytesToHex2(bytes.slice(offset, offset + pathLength)) + }); + } else { + let pathDescription = "Routing path information"; + if (routeType === 2 /* Direct */ || routeType === 3 /* TransportDirect */) { + pathDescription = "Routing instructions (bytes are stripped at each hop as packet travels to destination)"; + } else if (routeType === 1 /* Flood */ || routeType === 0 /* TransportFlood */) { + pathDescription = "Historical route taken (bytes are added as packet floods through network)"; + } + segments.push({ + name: "Path Data", + description: pathDescription, + startByte: offset, + endByte: offset + pathLength - 1, + value: bytesToHex2(bytes.slice(offset, offset + pathLength)) + }); + } + } + offset += pathLength; + const payloadBytes = bytes.subarray(offset); + const payloadHex = bytesToHex2(payloadBytes); + if (includeStructure && bytes.length > offset) { + segments.push({ + name: "Payload", + description: `${getPayloadTypeName(payloadType)} payload data`, + startByte: offset, + endByte: bytes.length - 1, + value: bytesToHex2(bytes.slice(offset)) + }); + } + let decodedPayload = null; + const payloadSegments = []; + if (payloadType === 4 /* Advert */) { + const result = AdvertPayloadDecoder.decode(payloadBytes, { + includeSegments: includeStructure, + segmentOffset: 0 + }); + decodedPayload = result; + if (result?.segments) { + payloadSegments.push(...result.segments); + delete result.segments; + } + } else if (payloadType === 9 /* Trace */) { + const result = TracePayloadDecoder.decode(payloadBytes, path, { + includeSegments: includeStructure, + segmentOffset: 0 + // Payload segments are relative to payload start + }); + decodedPayload = result; + if (result?.segments) { + payloadSegments.push(...result.segments); + delete result.segments; + } + } else if (payloadType === 5 /* GroupText */) { + const result = GroupTextPayloadDecoder.decode(payloadBytes, { + ...options, + includeSegments: includeStructure, + segmentOffset: 0 + }); + decodedPayload = result; + if (result?.segments) { + payloadSegments.push(...result.segments); + delete result.segments; + } + } else if (payloadType === 0 /* Request */) { + const result = RequestPayloadDecoder.decode(payloadBytes, { + includeSegments: includeStructure, + segmentOffset: 0 + // Payload segments are relative to payload start + }); + decodedPayload = result; + if (result?.segments) { + payloadSegments.push(...result.segments); + delete result.segments; + } + } else if (payloadType === 1 /* Response */) { + const result = ResponsePayloadDecoder.decode(payloadBytes, { + includeSegments: includeStructure, + segmentOffset: 0 + // Payload segments are relative to payload start + }); + decodedPayload = result; + if (result?.segments) { + payloadSegments.push(...result.segments); + delete result.segments; + } + } else if (payloadType === 7 /* AnonRequest */) { + const result = AnonRequestPayloadDecoder.decode(payloadBytes, { + includeSegments: includeStructure, + segmentOffset: 0 + }); + decodedPayload = result; + if (result?.segments) { + payloadSegments.push(...result.segments); + delete result.segments; + } + } else if (payloadType === 3 /* Ack */) { + const result = AckPayloadDecoder.decode(payloadBytes, { + includeSegments: includeStructure, + segmentOffset: 0 + }); + decodedPayload = result; + if (result?.segments) { + payloadSegments.push(...result.segments); + delete result.segments; + } + } else if (payloadType === 8 /* Path */) { + decodedPayload = PathPayloadDecoder.decode(payloadBytes); + } else if (payloadType === 2 /* TextMessage */) { + const result = TextMessagePayloadDecoder.decode(payloadBytes, { + includeSegments: includeStructure, + segmentOffset: 0 + }); + decodedPayload = result; + if (result?.segments) { + payloadSegments.push(...result.segments); + delete result.segments; + } + } else if (payloadType === 11 /* Control */) { + const result = ControlPayloadDecoder.decode(payloadBytes, { + includeSegments: includeStructure, + segmentOffset: 0 + }); + decodedPayload = result; + if (result?.segments) { + payloadSegments.push(...result.segments); + delete result.segments; + } + } + if (includeStructure && payloadSegments.length === 0 && bytes.length > offset) { + payloadSegments.push({ + name: `${getPayloadTypeName(payloadType)} Payload`, + description: `Raw ${getPayloadTypeName(payloadType)} payload data (${payloadBytes.length} bytes)`, + startByte: 0, + endByte: payloadBytes.length - 1, + value: bytesToHex2(payloadBytes) + }); + } + const messageHash = this.calculateMessageHash(bytes, routeType, payloadType, payloadVersion); + const packet = { + messageHash, + routeType, + payloadType, + payloadVersion, + transportCodes, + pathLength, + path, + payload: { + raw: payloadHex, + decoded: decodedPayload + }, + totalBytes: bytes.length, + isValid: true + }; + const structure = { + segments, + totalBytes: bytes.length, + rawHex: hexData.toUpperCase(), + messageHash, + payload: { + segments: payloadSegments, + hex: payloadHex, + startByte: offset, + type: getPayloadTypeName(payloadType) + } + }; + return { packet, structure }; + } catch (error) { + const errorPacket = { + messageHash: "", + routeType: 1 /* Flood */, + payloadType: 15 /* RawCustom */, + payloadVersion: 0 /* Version1 */, + pathLength: 0, + path: null, + payload: { raw: "", decoded: null }, + totalBytes: bytes.length, + isValid: false, + errors: [error instanceof Error ? error.message : "Unknown decoding error"] + }; + const errorStructure = { + segments: [], + totalBytes: bytes.length, + rawHex: hexData.toUpperCase(), + messageHash: "", + payload: { + segments: [], + hex: "", + startByte: 0, + type: "Unknown" + } + }; + return { packet: errorPacket, structure: errorStructure }; + } + } + /** + * Internal unified parsing method with signature verification for advertisements + */ + static async parseInternalAsync(hexData, includeStructure, options) { + const result = this.parseInternal(hexData, includeStructure, options); + if (result.packet.payloadType === 4 /* Advert */ && result.packet.payload.decoded) { + try { + const advertPayload = result.packet.payload.decoded; + const verifiedAdvert = await AdvertPayloadDecoder.decodeWithVerification( + hexToBytes2(result.packet.payload.raw), + { + includeSegments: includeStructure, + segmentOffset: 0 + } + ); + if (verifiedAdvert) { + result.packet.payload.decoded = verifiedAdvert; + if (!verifiedAdvert.isValid) { + result.packet.isValid = false; + result.packet.errors = verifiedAdvert.errors || ["Invalid advertisement signature"]; + } + if (includeStructure && verifiedAdvert.segments) { + result.structure.payload.segments = verifiedAdvert.segments; + delete verifiedAdvert.segments; + } + } + } catch (error) { + console.error("Signature verification failed:", error); + } + } + return result; + } + /** + * Validate packet format without full decoding + */ + static validate(hexData) { + const bytes = hexToBytes2(hexData); + const errors = []; + if (bytes.length < 2) { + errors.push("Packet too short (minimum 2 bytes required)"); + return { isValid: false, errors }; + } + try { + let offset = 1; + const header = bytes[0]; + const routeType = header & 3; + if (routeType === 0 /* TransportFlood */ || routeType === 3 /* TransportDirect */) { + if (bytes.length < offset + 4) { + errors.push("Packet too short for transport codes"); + } + offset += 4; + } + if (bytes.length < offset + 1) { + errors.push("Packet too short for path length"); + } else { + const pathLength = bytes[offset]; + offset += 1; + if (bytes.length < offset + pathLength) { + errors.push("Packet too short for path data"); + } + offset += pathLength; + } + if (offset >= bytes.length) { + errors.push("No payload data found"); + } + } catch (error) { + errors.push(error instanceof Error ? error.message : "Validation error"); + } + return { isValid: errors.length === 0, errors: errors.length > 0 ? errors : void 0 }; + } + /** + * Calculate message hash for a packet + */ + static calculateMessageHash(bytes, routeType, payloadType, payloadVersion) { + if (payloadType === 9 /* Trace */ && bytes.length >= 13) { + let offset2 = 1; + if (routeType === 0 /* TransportFlood */ || routeType === 3 /* TransportDirect */) { + offset2 += 4; + } + if (bytes.length > offset2) { + const pathLen = bytes[offset2]; + offset2 += 1 + pathLen; + } + if (bytes.length >= offset2 + 4) { + const traceTag = bytes[offset2] | bytes[offset2 + 1] << 8 | bytes[offset2 + 2] << 16 | bytes[offset2 + 3] << 24; + return numberToHex(traceTag, 8); + } + } + const constantHeader = payloadType << 2 | payloadVersion << 6; + let offset = 1; + if (routeType === 0 /* TransportFlood */ || routeType === 3 /* TransportDirect */) { + offset += 4; + } + if (bytes.length > offset) { + const pathLen = bytes[offset]; + offset += 1 + pathLen; + } + const payloadData = bytes.slice(offset); + const hashInput = [constantHeader, ...Array.from(payloadData)]; + let hash = 0; + for (let i = 0; i < hashInput.length; i++) { + hash = (hash << 5) - hash + hashInput[i] & 4294967295; + } + return numberToHex(hash, 8); + } + /** + * Create a key store for decryption + */ + static createKeyStore(initialKeys) { + return new MeshCoreKeyStore(initialKeys); + } +}; + +// src/browser/index.ts +function sha512Pure(data) { + const wordArray = import_crypto_js2.default.lib.WordArray.create(data); + const hash = import_crypto_js2.default.SHA512(wordArray); + const hashBytes = new Uint8Array(64); + for (let i = 0; i < 16; i++) { + const word = hash.words[i] || 0; + hashBytes[i * 4] = word >>> 24 & 255; + hashBytes[i * 4 + 1] = word >>> 16 & 255; + hashBytes[i * 4 + 2] = word >>> 8 & 255; + hashBytes[i * 4 + 3] = word & 255; + } + return hashBytes; +} +etc.sha512Sync = sha512Pure; +etc.sha512Async = async (data) => sha512Pure(data); +var Ed25519SignatureVerifier2 = class { + /** + * Verify an Ed25519 signature for MeshCore advertisement packets + * Uses @noble/ed25519 with crypto-js SHA-512 (works in insecure contexts) + */ + static async verifyAdvertisementSignature(publicKeyHex, signatureHex, timestamp, appDataHex) { + try { + const publicKey = hexToBytes2(publicKeyHex); + const signature = hexToBytes2(signatureHex); + const appData = hexToBytes2(appDataHex); + const message = this.constructAdvertSignedMessage(publicKeyHex, timestamp, appData); + return await verify(signature, message, publicKey); + } catch (error) { + console.error("Ed25519 signature verification failed:", error); + return false; + } + } + static constructAdvertSignedMessage(publicKeyHex, timestamp, appData) { + const publicKey = hexToBytes2(publicKeyHex); + const timestampBytes = new Uint8Array(4); + timestampBytes[0] = timestamp & 255; + timestampBytes[1] = timestamp >> 8 & 255; + timestampBytes[2] = timestamp >> 16 & 255; + timestampBytes[3] = timestamp >> 24 & 255; + const message = new Uint8Array(32 + 4 + appData.length); + message.set(publicKey, 0); + message.set(timestampBytes, 32); + message.set(appData, 36); + return message; + } + static getSignedMessageHex(publicKeyHex, timestamp, appDataHex) { + const appData = hexToBytes2(appDataHex); + const message = this.constructAdvertSignedMessage(publicKeyHex, timestamp, appData); + return bytesToHex2(message); + } +}; +function decodePacket(hexData, options) { + return MeshCorePacketDecoder.decode(hexData, options); +} +function analyzePacket(hexData, options) { + return MeshCorePacketDecoder.analyzeStructure(hexData, options); +} +async function decodePacketWithVerification(hexData, options) { + return MeshCorePacketDecoder.decodeWithVerification(hexData, options); +} +function isSecureContext() { + if (typeof globalThis === "undefined" || typeof globalThis.window === "undefined") { + return true; + } + return globalThis.isSecureContext ?? false; +} +function hasWebCrypto() { + return typeof globalThis !== "undefined" && globalThis.crypto !== void 0 && globalThis.crypto.subtle !== void 0; +} +export { + AdvertFlags, + ChannelCrypto, + ControlSubType, + DeviceRole, + Ed25519SignatureVerifier2 as Ed25519SignatureVerifier, + MeshCorePacketDecoder as MeshCoreDecoder, + MeshCoreKeyStore, + MeshCorePacketDecoder, + PayloadType, + PayloadVersion, + RequestType, + RouteType, + analyzePacket, + byteToHex, + bytesToHex2 as bytesToHex, + decodePacket, + decodePacketWithVerification, + ed25519_exports as ed25519, + getControlSubTypeName, + getDeviceRoleName, + getPayloadTypeName, + getPayloadVersionName, + getRequestTypeName, + getRouteTypeName, + hasWebCrypto, + hexToBytes2 as hexToBytes, + isSecureContext, + numberToHex +}; +/*! Bundled license information: + +crypto-js/ripemd160.js: + (** @preserve + (c) 2012 by Cédric Mesnil. All rights reserved. + + Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met: + + - Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer. + - Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution. + + THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + *) + +crypto-js/mode-ctr-gladman.js: + (** @preserve + * Counter block mode compatible with Dr Brian Gladman fileenc.c + * derived from CryptoJS.mode.CTR + * Jan Hruby jhruby.web@gmail.com + *) + +@noble/ed25519/index.js: + (*! noble-ed25519 - MIT License (c) 2019 Paul Miller (paulmillr.com) *) +*/ diff --git a/modules/web_viewer/templates/base.html b/modules/web_viewer/templates/base.html index 0ddab5a..7bf6d66 100644 --- a/modules/web_viewer/templates/base.html +++ b/modules/web_viewer/templates/base.html @@ -444,7 +444,10 @@ - + + + + - - {% endblock %}