iboot-http-client 1.2.2 → 1.2.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const L=require("pino"),B=require("pino-pretty"),D=require("js-md5"),m=require("crypto-js"),K={GENERAL:0,PHONE:1,EMAIL:2},R={TYPE_MGT:0,TYPE_C:1,TYPE_B:2},j={FROM_WEB:1,FROM_PC:2,FROM_WX_MINI_PRO:3,FROM_WX_PLU:4,FROM_WX_E:5,FROM_APP:6,FROM_DEVICE:7},H={unknown:0,male:1,female:2},$=B({colorize:!0,destination:process.stdout,translateTime:"SYS:yyyy-mm-dd HH:MM:ss",ignore:"pid,hostname",messageFormat:"{msg}",singleLine:!0}),u=L({name:process.env.APP_NAME??"iBoot",level:process.env.APP_ENV==="production"?"info":"debug",nestedKey:"payload"},$),T=n=>Array.isArray(n)||typeof n=="object"&&Object.prototype.toString.call(n)==="[object Array]",_=n=>{const t=n||32,e="ABCDEFGHJKMNPQRSTWXYZabcdefhijkmnprstwxyz2345678",r=e.length;let s="";for(let o=0;o<t;o++)s+=e.charAt(Math.floor(Math.random()*r));return s},U=(n,t)=>{const e={};return n.split("&").forEach(s=>{const o=s.split("=");o[1]&&(!t||t.indexOf(o[0])==-1)&&(e[o[0]]=o[1])}),e},p=n=>!n||n==""||n.length==0?"":encodeURIComponent(n).replace(/\(/g,"%28").replace(/\)/g,"%29").replace(/\'/g,"%27").replace(/\!/g,"%21").replace(/\~/g,"%7E"),x=(n,t)=>{const e={"M+":n.getMonth()+1,"d+":n.getDate(),"h+":n.getHours(),"m+":n.getMinutes(),"s+":n.getSeconds(),"q+":Math.floor((n.getMonth()+3)/3),S:n.getMilliseconds()};if(/(y+)/.test(t)){const s=new RegExp(/(y+)/).exec(t);let o=0;s&&s.length>0&&(o=s[0].length),t=t.replace(/(y+)/,n.getFullYear()+"").substring(4-o)}for(const r in e){const s="("+r+")",o=new RegExp(s);if(o.test(t)){const i=o.exec(t);let a=0;i&&i.length>0&&(a=i[0].length),t=t.replace(o,a==1?e[r].toString():("00"+e[r]).substring(e[r].toString().length))}}return t},N="zh-CN",S="_device_id_key",O="_current_website_key",A="Get request error!",w="Post request error!",E={IBOOT_DEVICE_ID:"dvid",IBOOT_LANG:"lang",IBOOT_WEBSITE_ID:"wid",IBOOT_WEBSITE_NO:"wno",IBOOT_TOKEN:"token",IBOOT_USER:"user"},y={DEVICE_ID:"Device-Id",LANG:"Lang",WEBSITE_ID:"Website-Id",WEBSITE_NO:"Website-No"},M=n=>{if(!n.get)throw new Error("The get method of IStorage has not been implemented.");const t=n.get(S)??"",e=n.get(O),r=e!=null?JSON.parse(e):null,s={};return t.length>0&&(s["Device-Id"]=t),r&&(s.Lang=r.language,r.websiteId&&(s["Website-Id"]=r.websiteId),r.websiteNo&&(s["Website-No"]=r.websiteNo)),s},F=({deviceId:n,website:t},e)=>{if(!e.set)throw new Error("The set method of IStorage has not been implemented.");e.set(S,n),t&&e.set(O,JSON.stringify(t))},v=async(n,t)=>{if(t?.data){const i=new URLSearchParams(t.data);n.indexOf("?")!=-1?n+=`&${i}`:n+=`?${i}`}const e=t&&t.storage&&t.storage.get?M(t.storage):{},r=t?.headers;if(r)for(const i in r){const a=r[i];a&&(e[i]=a)}u.info({url:n,headers:e},"GET");const s=await fetch(n,{method:"GET",headers:e,cache:t?.useCache?"force-cache":"default"});if(s.ok){const i=Object.fromEntries(s.headers.entries()),a={...await s.json(),headers:i};return u.debug(a,"GET_RESULT"),a}const o={code:s.status,success:!1,msg:s.statusText};return u.error(o),o},b=async(n,t)=>{const e=t?.data??{},r=t?.headers;let s;const o=t&&t.storage&&t.storage.get?M(t.storage):{},i=new Headers(o);if(e instanceof FormData?s=e:(s=JSON.stringify(e),i.set("Content-Type","application/json")),r)for(let l in r){const h=r[l];h&&i.set(l,h)}u.info({url:n,headers:i},"POST");const a=await fetch(n,{method:"POST",headers:i,body:s});if(a.ok){const l=Object.fromEntries(a.headers.entries()),h={...await a.json(),headers:l};return u.debug(h,"POST_RESULT"),h}const c={code:a.status,success:!1,msg:a.statusText};return u.error(c),c},W=async(n,t)=>{const e=await v(n,t);if(e.success)return e.data;if(t?.showError){t.showError(e.msg??A);return}throw Error(e.msg??A)},k=async(n,t)=>{const e=await b(n,t);if(e.success)return e.data;if(t?.showError){t.showError(e.msg??w);return}throw Error(e.msg??w)},G=async(n,t)=>{const e=await b(n,t);return e.success?(t?.showSuccess&&t.showSuccess(e.msg??"SUCCESS"),!0):(t?.showError&&t.showError(e.msg??w),!1)},Y=n=>{if(n.get){const t=n.get(y.DEVICE_ID),e=n.get(y.LANG),r=n.get(y.WEBSITE_ID),s=n.get(y.WEBSITE_NO),o={};return t&&t.length>0&&(o.deviceId=t),e&&e.length>0&&(o.lang=e),r&&r.length>0&&(o.websiteId=r),s&&s.length>0&&(o.websiteNo=s),o}throw new Error("The set method of IStorage has not been implemented.")},J=n=>{if(n.get){const t=n.get(E.IBOOT_USER);if(t&&t.length>0)return JSON.parse(t)}},q=n=>{if(n.get){const t=n.get(E.IBOOT_USER);if(t&&t.length>0){const e=JSON.parse(t),r=e.username,s=e.userType.toString(),o=n.get(E.IBOOT_TOKEN);if(o)return{username:r,utype:s,token:o}}}},V=(n,t)=>{const{id:e,name:r,username:s,nickname:o,headImg:i,token:a,lastLoginTime:c,deviceId:l,userType:h,mustChangePwd:g}=n,d={id:e,name:r,username:s,nickname:o||r,headImg:i,lastLoginTime:c,deviceId:l,userType:h,accountType:0,needToReview:!1,socketOnline:!1,mustChangePwd:g};if(!t.set)throw new Error("cookies set function is undefined");t.set(E.IBOOT_TOKEN,a,{path:"/",secure:process.env.APP_ENV==="production",httpOnly:!0,sameSite:"strict"}),t.set(E.IBOOT_USER,JSON.stringify(d))},X=n=>{if(!n.set)throw new Error("cookies set function is undefined");if(n.set(E.IBOOT_TOKEN,"",{maxAge:-1,httpOnly:!0,path:"/"}),n.set(E.IBOOT_USER,"",{maxAge:-1,httpOnly:!0,path:"/"}),!n.delete)throw new Error("cookies delete function is undefined");n.delete(E.IBOOT_TOKEN),n.delete(E.IBOOT_USER)};class z{baseUrl;helloMethod;apiKey;userType;userFrom;deviceId;version="1";lang;websiteId;websiteNo;constructor(t){process.env.APP_ENV==="production"||u.warn("This is currently a development environment!"),this.baseUrl=process.env.APP_BASEURL,this.apiKey=process.env.APP_APIKEY,this.userFrom=process.env.APP_USERFROM??"1",this.helloMethod=t.helloURL??"",this.userType=t.userType??R.TYPE_MGT,this.deviceId=t.deviceId??_(10),this.lang=t.lang??N,this.websiteId=t.websiteId,this.websiteNo=t.websiteNo}encrypt(t){const e=m.enc.Utf8.parse(this.apiKey);return m.AES.encrypt(t,e).toString()}decrypt(t){const e=m.enc.Utf8.parse(this.apiKey);return m.AES.decrypt(t,e,{mode:m.mode.ECB}).toString(m.enc.Utf8)}convertUrlParameter(t){const e=[];for(const r in t){let s=t[r];if(s&&typeof s=="string")s=s.trim();else if(s&&typeof s=="object"){if(T(s)){if(s.length===0)continue;for(let o=0;o<s.length;o++){const i=s[o];for(const a in i){const c=i[a]??void 0;if(c){if(typeof c=="object")T(c)&&c.forEach((l,h)=>{if(l)for(const g in l){const d=l[g];if(d&&d.toString().length>0){const f=`[${o.toString()}].${a+`[${h.toString()}].${g}`}=${p(d)}`;e.push(r+f)}}});else if(c.toString().length>0){const l=`[${o.toString()}].${a}=${p(c.toString())}`;e.push(r+l)}}}}}else for(const o in s){const i=s[o];if(i!=null&&i!=""&&i.length!=0){const a=`.${o}=${p(i)}`;e.push(r+a)}}continue}else s&&typeof s=="function"&&(s=null);s!=null&&s!=""&&s.length!=0&&e.push(r+"="+p(s))}return e&&e.join("&")}async sign(t){const e="&key="+await this.helloIboot(),r=[];for(const c in t)r.push(c);r.sort((c,l)=>c.toLowerCase().localeCompare(l.toLowerCase()));const s=[];r.forEach(c=>{let l=t[c];typeof l=="object"&&(l=JSON.stringify(l)),s.push(c+"="+l)});const o=s.join("&"),i=D.md5((o+e).toLocaleUpperCase()),a={params:o,md5:i};return u.debug(a,"API_SIGN"),i}assemblyParameter(t,e){const r=t??{};return r.timestamp=Date.now()+"",r.echostr=_(10),r.version=this.version,r.deviceId=this.deviceId,r.webid=this.websiteId,r.apiKey=this.apiKey,e&&e.length>0&&(r.username=e),r}async assemblyHeader({urlParams:t,token:e}){const r={"Content-Type":"application/x-www-form-urlencoded","Res-Type":"json","Device-Id":this.deviceId,"User-Type":e?.utype.toString()??this.userType.toString(),"User-From":this.userFrom,"Api-Key":this.apiKey};this.lang&&this.lang.length>0&&(r.Lang=this.lang),this.websiteId&&this.websiteId.length>0&&(r["Web-Id"]=this.websiteId),this.websiteNo&&this.websiteNo.length>0&&(r["Web-No"]=this.websiteNo),e&&(e.token&&e.token.length>0&&e.username&&e.username.length>0&&(r.Authorization=e.token,r.Username=e.username),e.xcsrf&&(r[e.xcsrf.csrfHeader]=e.xcsrf.csrfToken));const s=U(t),o=await this.sign(s);return r.Sign=o,r}async helloIboot(){if(this.helloMethod.length<=0)return this.apiKey;const t=this.getApiUrl(this.helloMethod),e={"Content-Type":"application/x-www-form-urlencoded","Res-Type":"json","Api-Key":this.apiKey},r={url:t,headers:e};u.debug(r,"HELLO");const s=await fetch(t,{method:"GET",headers:e,credentials:"include",cache:"force-cache"});if(s.ok){const o=await s.json();return u.debug(o.data,"HELLO RESULT"),o.data}throw new Error("hello iBoot error!")}getApiUrl(t){return`${this.baseUrl}/${t}`}async csrf(){const t=await this.get({url:"guest/csrf"});if(t.success){const e=t.data;if(e)return e.csrfToken.toString()}}async get({url:t,data:e,token:r,cache:s="default"}){const o=this.assemblyParameter(e),i=this.convertUrlParameter(o),a=await this.assemblyHeader({urlParams:i,token:r}),c=`${this.getApiUrl(t)}?${i.toString()}`,l={url:c,headers:a};u.info(l,"GET");const h=await fetch(c,{method:"GET",headers:a,credentials:"include",cache:s});if(h.ok){const d=Object.fromEntries(h.headers.entries()),f={...await h.json(),headers:d};return u.debug(f,"GET_RESULT"),f}const g={code:h.status,success:!1,msg:h.statusText};return u.error(g),g}async post({url:t,data:e,token:r,cache:s="default"}){e=e?{...e}:{};const o=e.buffer??void 0,i=e.boundary??void 0;o&&delete e.buffer,i&&delete e.boundary;const a=this.assemblyParameter(e),c=this.convertUrlParameter(a),l=await this.assemblyHeader({urlParams:c,token:r});o&&i&&(l["Content-Type"]=`multipart/form-data; boundary=${i}`);const h=this.getApiUrl(t),g={url:h,headers:l,params:a};u.info(g,"POST");const d=o?`${h}?${c}`:h,f=await fetch(d,{method:"POST",headers:l,body:o||c.toString(),credentials:"include",cache:s});if(f.ok){const C=Object.fromEntries(f.headers.entries()),P={...await f.json(),headers:C};return u.debug(P,"POST_RESULT"),P}const I={code:f.status,success:!1,msg:f.statusText};return u.error(I),I}async stream({url:t,data:e,token:r}){e=e?{...e}:{};const s=e.buffer??void 0,o=e.boundary??void 0;s&&delete e.buffer,o&&delete e.boundary;const i=this.assemblyParameter(e),a=this.convertUrlParameter(i),c=await this.assemblyHeader({urlParams:a,token:r});s&&o&&(c["Content-Type"]=`multipart/form-data; boundary=${o}`),c.Connection="keep-alive",c["X-Accel-Buffering"]="no",c["Cache-Control"]="no-cache";const l=this.getApiUrl(t);try{const h=s?`${l}?${a}`:l,g={url:l,headers:c,params:i};u.info(g,"STREAM");const d=await fetch(h,{method:"POST",headers:c,body:s||a.toString(),credentials:"include"});if(!d.ok)throw new Error(`HTTP error! status: ${d.status}`);if(!d.body)throw new Error("No response body");const f=Object.fromEntries(d.headers.entries());return new Response(d.body,{headers:f})}catch(h){throw h}}}exports.ACCOUNT_TYPE_MAP=K;exports.COOKIE_NAMES=E;exports.CURRENT_WEBSITE_KEY=O;exports.DEFAULT_LOCALE=N;exports.DEVICE_ID_KEY=S;exports.HttpClient=z;exports.USER_FORM_MAP=j;exports.USER_SEX_MAP=H;exports.USER_TYPE_MAP=R;exports.cleanToken=X;exports.dateFormat=x;exports.get=v;exports.getHttpOpts=Y;exports.getLoginUser=J;exports.getToken=q;exports.iGet=W;exports.iPost=k;exports.iPostSuccess=G;exports.isArray=T;exports.logger=u;exports.post=b;exports.randomString=_;exports.setDefaultRequestHeader=F;exports.setToken=V;exports.urlEncode=p;exports.urlParamToJson=U;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const L=require("pino"),B=require("pino-pretty"),D=require("js-md5"),m=require("crypto-js"),K={GENERAL:0,PHONE:1,EMAIL:2},R={TYPE_MGT:0,TYPE_C:1,TYPE_B:2},j={FROM_WEB:1,FROM_PC:2,FROM_WX_MINI_PRO:3,FROM_WX_PLU:4,FROM_WX_E:5,FROM_APP:6,FROM_DEVICE:7},H={unknown:0,male:1,female:2},$=B({colorize:!0,destination:process.stdout,translateTime:"SYS:yyyy-mm-dd HH:MM:ss",ignore:"pid,hostname",messageFormat:"{msg}",singleLine:!0}),u=L({name:process.env.APP_NAME??"iBoot",level:process.env.APP_ENV==="production"?"info":"debug",nestedKey:"payload"},$),T=n=>Array.isArray(n)||typeof n=="object"&&Object.prototype.toString.call(n)==="[object Array]",_=n=>{const t=n||32,e="ABCDEFGHJKMNPQRSTWXYZabcdefhijkmnprstwxyz2345678",r=e.length;let s="";for(let o=0;o<t;o++)s+=e.charAt(Math.floor(Math.random()*r));return s},U=(n,t)=>{const e={};return n.split("&").forEach(s=>{const o=s.split("=");o[1]&&(!t||t.indexOf(o[0])==-1)&&(e[o[0]]=o[1])}),e},p=n=>!n||n==""||n.length==0?"":encodeURIComponent(n).replace(/\(/g,"%28").replace(/\)/g,"%29").replace(/\'/g,"%27").replace(/\!/g,"%21").replace(/\~/g,"%7E"),x=(n,t)=>{const e={"M+":n.getMonth()+1,"d+":n.getDate(),"h+":n.getHours(),"m+":n.getMinutes(),"s+":n.getSeconds(),"q+":Math.floor((n.getMonth()+3)/3),S:n.getMilliseconds()};if(/(y+)/.test(t)){const s=new RegExp(/(y+)/).exec(t);let o=0;s&&s.length>0&&(o=s[0].length),t=t.replace(/(y+)/,n.getFullYear()+"").substring(4-o)}for(const r in e){const s="("+r+")",o=new RegExp(s);if(o.test(t)){const i=o.exec(t);let a=0;i&&i.length>0&&(a=i[0].length),t=t.replace(o,a==1?e[r].toString():("00"+e[r]).substring(e[r].toString().length))}}return t},N="zh-CN",w="_device_id_key",O="_current_website_key",A="Get request error!",S="Post request error!",E={IBOOT_DEVICE_ID:"dvid",IBOOT_LANG:"lang",IBOOT_WEBSITE_ID:"wid",IBOOT_WEBSITE_NO:"wno",IBOOT_TOKEN:"token",IBOOT_USER:"user"},y={DEVICE_ID:"Device-Id",LANG:"Lang",WEBSITE_ID:"Website-Id",WEBSITE_NO:"Website-No"},M=n=>{if(!n.get)throw new Error("The get method of IStorage has not been implemented.");const t=n.get(w)??"",e=n.get(O),r=e!=null?JSON.parse(e):null,s={};return t.length>0&&(s["Device-Id"]=t),r&&(s.Lang=r.language,r.websiteId&&(s["Website-Id"]=r.websiteId),r.websiteNo&&(s["Website-No"]=r.websiteNo)),s},F=({deviceId:n,website:t},e)=>{if(!e.set)throw new Error("The set method of IStorage has not been implemented.");e.set(w,n),t&&e.set(O,JSON.stringify(t))},v=async(n,t)=>{if(t?.data){const i=new URLSearchParams(t.data);n.indexOf("?")!=-1?n+=`&${i}`:n+=`?${i}`}const e=t&&t.storage&&t.storage.get?M(t.storage):{},r=t?.headers;if(r)for(const i in r){const a=r[i];a&&(e[i]=a)}u.info({url:n,headers:e},"GET");const s=await fetch(n,{method:"GET",headers:e,cache:t?.useCache?"force-cache":"default"});if(s.ok){const i=Object.fromEntries(s.headers.entries()),a={...await s.json(),headers:i};return u.debug(a,"GET_RESULT"),a}const o={code:s.status,success:!1,msg:s.statusText};return u.error(o),o},b=async(n,t)=>{const e=t?.data??{},r=t?.headers;let s;const o=t&&t.storage&&t.storage.get?M(t.storage):{},i=new Headers(o);if(e instanceof FormData?s=e:(s=JSON.stringify(e),i.set("Content-Type","application/json")),r)for(let l in r){const h=r[l];h&&i.set(l,h)}u.info({url:n,headers:i},"POST");const a=await fetch(n,{method:"POST",headers:i,body:s});if(a.ok){const l=Object.fromEntries(a.headers.entries()),h={...await a.json(),headers:l};return u.debug(h,"POST_RESULT"),h}const c={code:a.status,success:!1,msg:a.statusText};return u.error(c),c},W=async(n,t)=>{const e=await v(n,t);if(e.success)return e.data;if(t?.showError){t.showError(e.msg??A);return}throw Error(e.msg??A)},k=async(n,t)=>{const e=await b(n,t);if(e.success)return e.data;if(t?.showError){t.showError(e.msg??S);return}throw Error(e.msg??S)},G=async(n,t)=>{const e=await b(n,t);return e.success?(t?.showSuccess&&t.showSuccess(e.msg??"SUCCESS"),!0):(t?.showError&&t.showError(e.msg??S),!1)},Y=n=>{if(n.get){const t=n.get(y.DEVICE_ID),e=n.get(y.LANG),r=n.get(y.WEBSITE_ID),s=n.get(y.WEBSITE_NO),o={};return t&&t.length>0&&(o.deviceId=t),e&&e.length>0&&(o.lang=e),r&&r.length>0&&(o.websiteId=r),s&&s.length>0&&(o.websiteNo=s),o}throw new Error("The set method of IStorage has not been implemented.")},J=n=>{if(n.get){const t=n.get(E.IBOOT_USER);if(t&&t.length>0)return JSON.parse(t)}},q=n=>{if(n.get){const t=n.get(E.IBOOT_USER);if(t&&t.length>0){const e=JSON.parse(t),r=e.username,s=e.userType.toString(),o=n.get(E.IBOOT_TOKEN);if(o)return{username:r,utype:s,token:o}}}},V=(n,t)=>{const{id:e,name:r,username:s,nickname:o,headImg:i,token:a,lastLoginTime:c,deviceId:l,userType:h,mustChangePwd:g}=n,d={id:e,name:r,username:s,nickname:o||r,headImg:i,lastLoginTime:c,deviceId:l,userType:h,accountType:0,needToReview:!1,socketOnline:!1,mustChangePwd:g};if(!t.set)throw new Error("cookies set function is undefined");t.set(E.IBOOT_TOKEN,a,{path:"/",secure:process.env.APP_ENV==="production",httpOnly:!0,sameSite:"strict"}),t.set(E.IBOOT_USER,JSON.stringify(d))},X=n=>{if(!n.set)throw new Error("cookies set function is undefined");if(n.set(E.IBOOT_TOKEN,"",{maxAge:-1,httpOnly:!0,path:"/"}),n.set(E.IBOOT_USER,"",{maxAge:-1,httpOnly:!0,path:"/"}),!n.delete)throw new Error("cookies delete function is undefined");n.delete(E.IBOOT_TOKEN),n.delete(E.IBOOT_USER)};class z{baseUrl;helloMethod;apiKey;userType;userFrom;deviceId;version="1";lang;websiteId;websiteNo;constructor(t){process.env.APP_ENV==="production"||u.warn("This is currently a development environment!"),this.baseUrl=process.env.APP_BASEURL,this.apiKey=process.env.APP_APIKEY,this.userFrom=process.env.APP_USERFROM??"1",this.helloMethod=t.helloURL??"",this.userType=t.userType??R.TYPE_MGT,this.deviceId=t.deviceId??_(10),this.lang=t.lang??N,this.websiteId=t.websiteId,this.websiteNo=t.websiteNo}encrypt(t){const e=m.enc.Utf8.parse(this.apiKey);return m.AES.encrypt(t,e).toString()}decrypt(t){const e=m.enc.Utf8.parse(this.apiKey);return m.AES.decrypt(t,e,{mode:m.mode.ECB}).toString(m.enc.Utf8)}convertUrlParameter(t){const e=[];for(const r in t){let s=t[r];if(s&&typeof s=="string")s=s.trim();else if(s&&typeof s=="object"){if(T(s)){if(s.length===0)continue;for(let o=0;o<s.length;o++){const i=s[o];for(const a in i){const c=i[a]??void 0;if(c){if(typeof c=="object")T(c)&&c.forEach((l,h)=>{if(l)for(const g in l){const d=l[g];if(d&&d.toString().length>0){const f=`[${o.toString()}].${a+`[${h.toString()}].${g}`}=${p(d)}`;e.push(r+f)}}});else if(c.toString().length>0){const l=`[${o.toString()}].${a}=${p(c.toString())}`;e.push(r+l)}}}}}else for(const o in s){const i=s[o];if(i!=null&&i!=""&&i.length!=0){const a=`.${o}=${p(i)}`;e.push(r+a)}}continue}else s&&typeof s=="function"&&(s=null);s!=null&&s!=""&&s.length!=0&&e.push(r+"="+p(s))}return e&&e.join("&")}async sign(t){const e="&key="+await this.helloIboot(),r=[];for(const c in t)r.push(c);r.sort((c,l)=>c.toLowerCase().localeCompare(l.toLowerCase()));const s=[];r.forEach(c=>{let l=t[c];typeof l=="object"&&(l=JSON.stringify(l)),s.push(c+"="+l)});const o=s.join("&"),i=D.md5((o+e).toLocaleUpperCase()),a={params:o,md5:i};return u.debug(a,"API_SIGN"),i}assemblyParameter(t,e){const r=t??{};return r.timestamp=Date.now()+"",r.echostr=_(10),r.version=this.version,r.deviceId=this.deviceId,r.webid=this.websiteId,r.apiKey=this.apiKey,e&&e.length>0&&(r.username=e),r}async assemblyHeader({urlParams:t,token:e}){const r={"Content-Type":"application/x-www-form-urlencoded","Res-Type":"json","Device-Id":this.deviceId,"User-Type":e?.utype.toString()??this.userType.toString(),"User-From":this.userFrom,"Api-Key":this.apiKey};this.lang&&this.lang.length>0&&(r.Lang=this.lang),this.websiteId&&this.websiteId.length>0&&(r["Web-Id"]=this.websiteId),this.websiteNo&&this.websiteNo.length>0&&(r["Web-No"]=this.websiteNo),e&&(e.token&&e.token.length>0&&e.username&&e.username.length>0&&(r.Authorization=e.token,r.Username=e.username),e.xcsrf&&(r[e.xcsrf.csrfHeader]=e.xcsrf.csrfToken));const s=U(t),o=await this.sign(s);return r.Sign=o,r}async helloIboot(){if(this.helloMethod.length<=0)return this.apiKey;const t=this.getApiUrl(this.helloMethod),e={"Content-Type":"application/x-www-form-urlencoded","Res-Type":"json","Api-Key":this.apiKey},r={url:t,headers:e};u.debug(r,"HELLO");const s=await fetch(t,{method:"GET",headers:e,credentials:"include",cache:"force-cache"});if(s.ok){const o=await s.json();return u.debug(o.data,"HELLO RESULT"),o.data}throw new Error("hello iBoot error!")}getApiUrl(t){return`${this.baseUrl}/${t}`}async csrf(){const t=await this.get({url:"guest/csrf"});if(t.success){const e=t.data;if(e)return e.csrfToken.toString()}}async get({url:t,data:e,token:r,cache:s="default"}){const o=this.assemblyParameter(e),i=this.convertUrlParameter(o),a=await this.assemblyHeader({urlParams:i,token:r}),c=`${this.getApiUrl(t)}?${i.toString()}`,l={url:c,headers:a};u.info(l,"GET");const h=await fetch(c,{method:"GET",headers:a,credentials:"include",cache:s});if(h.ok){const d=Object.fromEntries(h.headers.entries()),f={...await h.json(),headers:d};return u.debug(f,"GET_RESULT"),f}const g={code:h.status,success:!1,msg:h.statusText};return u.error(g),g}async post({url:t,data:e,token:r,cache:s="default"}){e=e?{...e}:{};const o=e.buffer??void 0,i=e.boundary??void 0;o&&delete e.buffer,i&&delete e.boundary;const a=this.assemblyParameter(e),c=this.convertUrlParameter(a),l=await this.assemblyHeader({urlParams:c,token:r});o&&i&&(l["Content-Type"]=`multipart/form-data; boundary=${i}`);const h=this.getApiUrl(t),g={url:h,headers:l,params:a};u.info(g,"POST");const d=o?`${h}?${c}`:h,f=await fetch(d,{method:"POST",headers:l,body:o||c.toString(),credentials:"include",cache:s});if(f.ok){const C=Object.fromEntries(f.headers.entries()),P={...await f.json(),headers:C};return u.debug(P,"POST_RESULT"),P}const I={code:f.status,success:!1,msg:f.statusText};return u.error(I),I}async stream({url:t,data:e,token:r}){e=e?{...e}:{};const s=e.buffer??void 0,o=e.boundary??void 0;s&&delete e.buffer,o&&delete e.boundary;const i=this.assemblyParameter(e),a=this.convertUrlParameter(i),c=await this.assemblyHeader({urlParams:a,token:r});s&&o&&(c["Content-Type"]=`multipart/form-data; boundary=${o}`),c.Connection="keep-alive",c["X-Accel-Buffering"]="no",c["Cache-Control"]="no-cache";const l=this.getApiUrl(t);try{const h=s?`${l}?${a}`:l,g={url:l,headers:c,params:i};u.info(g,"STREAM");const d=await fetch(h,{method:"POST",headers:c,body:s||a.toString(),credentials:"include"});if(!d.ok)throw new Error(`HTTP error! status: ${d.status}`);if(!d.body)throw new Error("No response body");const f=Object.fromEntries(d.headers.entries());return new Response(d.body,{headers:f})}catch(h){throw h}}}exports.ACCOUNT_TYPE_MAP=K;exports.COOKIE_NAMES=E;exports.CURRENT_WEBSITE_KEY=O;exports.DEFAULT_LOCALE=N;exports.DEVICE_ID_KEY=w;exports.HEADER_NAMES=y;exports.HttpClient=z;exports.USER_FORM_MAP=j;exports.USER_SEX_MAP=H;exports.USER_TYPE_MAP=R;exports.cleanToken=X;exports.dateFormat=x;exports.get=v;exports.getHttpOpts=Y;exports.getLoginUser=J;exports.getToken=q;exports.iGet=W;exports.iPost=k;exports.iPostSuccess=G;exports.isArray=T;exports.logger=u;exports.post=b;exports.randomString=_;exports.setDefaultRequestHeader=F;exports.setToken=V;exports.urlEncode=p;exports.urlParamToJson=U;
2
2
  //# sourceMappingURL=iboot-http-client.cjs.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"iboot-http-client.cjs.js","sources":["../src/types/user.ts","../src/logger.ts","../src/utils.ts","../src/http-client.ts"],"sourcesContent":["export const ACCOUNT_TYPE_MAP = {\r\n GENERAL : 0,\r\n PHONE : 1,\r\n EMAIL : 2\r\n}\r\n\r\nexport const USER_TYPE_MAP = {\r\n TYPE_MGT : 0,\r\n TYPE_C : 1,\r\n TYPE_B : 2\r\n}\r\n\r\nexport const USER_FORM_MAP = {\r\n FROM_WEB : 1,\r\n FROM_PC : 2,\r\n FROM_WX_MINI_PRO : 3,\r\n FROM_WX_PLU : 4,\r\n FROM_WX_E : 5,\r\n FROM_APP : 6,\r\n FROM_DEVICE : 7\r\n}\r\n\r\nexport const USER_SEX_MAP = {\r\n unknown:0,\r\n male:1,\r\n female:2,\r\n}\r\n\r\nexport type ACCOUNT_TYPE = typeof ACCOUNT_TYPE_MAP[keyof typeof ACCOUNT_TYPE_MAP];\r\nexport type USER_TYPE = typeof USER_TYPE_MAP[keyof typeof USER_TYPE_MAP];\r\nexport type USER_FORM = typeof USER_FORM_MAP[keyof typeof USER_FORM_MAP];\r\nexport type USER_SEX = typeof USER_SEX_MAP[keyof typeof USER_SEX_MAP];\r\n\r\n// User interface\r\nexport interface User {\r\n id: string;\r\n name: string;\r\n userType: USER_TYPE;\r\n username?: string;\r\n nickname?: string;\r\n sex?: USER_SEX;\r\n headImg?: string;\r\n lastLoginTime?: string;\r\n tokenExpired?: string;\r\n deviceId?: string;\r\n status?: number;\r\n accountType?: number;\r\n enabled?: boolean;\r\n userFrom?: USER_FORM;\r\n needToReview?: boolean;\r\n socketOnline?: boolean;\r\n createTime?: string;\r\n mustChangePwd?: boolean;\r\n}","import pino from \"pino\";\r\nimport PinoPretty from \"pino-pretty\";\r\n// import koffi from 'koffi';\r\n\r\n// if (typeof window === 'undefined' && process.platform === 'win32') {\r\n// try {\r\n// const CP_UTF8 = 65001;\r\n// const kernel32 = koffi.load('Kernel32');\r\n// const setConsoleOutputCP = kernel32.func('SetConsoleOutputCP', 'bool', ['int']);\r\n// const setConsoleCP = kernel32.func('SetConsoleCP', 'bool', ['int']);\r\n// setConsoleOutputCP(CP_UTF8);\r\n// setConsoleCP(CP_UTF8);\r\n// } catch (e) {\r\n// console.log(e);\r\n// }\r\n// }\r\n\r\n// export const logger = pino({\r\n// name: process.env.APP_NAME ?? 'iBoot',\r\n// level: process.env.NODE_ENV !== 'production' ? 'debug' : 'info',\r\n// nestedKey: 'payload',\r\n// transport: {\r\n// target: 'pino-pretty',\r\n// options: {\r\n// colorize: true,\r\n// translateTime: 'SYS:yyyy-mm-dd HH:MM:ss',\r\n// ignore: 'pid,hostname',\r\n// messageFormat: '{msg}',\r\n// singleLine: true,\r\n// },\r\n// }\r\n// });\r\n\r\nconst stream = PinoPretty({\r\n colorize: true,\r\n destination: process.stdout,\r\n translateTime: 'SYS:yyyy-mm-dd HH:MM:ss',\r\n ignore: 'pid,hostname',\r\n messageFormat: '{msg}',\r\n singleLine: true,\r\n});\r\n\r\nexport const logger = pino({\r\n name: process.env.APP_NAME ?? 'iBoot',\r\n level: process.env.APP_ENV === 'production' ? 'info' : 'debug',\r\n nestedKey: 'payload'\r\n}, stream);","export const isArray = (obj: unknown) => {\r\n return (\r\n Array.isArray(obj) ||\r\n (typeof obj === \"object\" &&\r\n Object.prototype.toString.call(obj) === \"[object Array]\")\r\n );\r\n};\r\n\r\n/**\r\n * 生成指定长度的随机串\r\n * @param {Object} len\r\n */\r\nexport const randomString = (len: number) => {\r\n const l = len || 32;\r\n const $chars = \"ABCDEFGHJKMNPQRSTWXYZabcdefhijkmnprstwxyz2345678\";\r\n const maxPos = $chars.length;\r\n let pwd = \"\";\r\n for (let i = 0; i < l; i++) {\r\n pwd += $chars.charAt(Math.floor(Math.random() * maxPos));\r\n }\r\n return pwd;\r\n};\r\n\r\nexport const urlParamToJson = (urlQueryParams: string, exclude?: string[]): Record<string, string> => {\r\n const result: Record<string, string> = {};\r\n const strs = urlQueryParams.split(\"&\");\r\n strs.forEach((item) => {\r\n const arr = item.split(\"=\");\r\n if (arr[1]) {\r\n if (!exclude || exclude.indexOf(arr[0]) == -1) {\r\n result[arr[0]] = arr[1];\r\n }\r\n }\r\n });\r\n return result;\r\n};\r\n\r\nexport const urlEncode = (value: string | null | undefined): string => {\r\n if (!value || value == \"\" || value.length == 0) {\r\n return \"\";\r\n }\r\n return (\r\n encodeURIComponent(value)\r\n // .replace(/%20/g, '+')\r\n // .replace(/%2B/g, '\\\\+')\r\n .replace(/\\(/g, \"%28\")\r\n .replace(/\\)/g, \"%29\")\r\n .replace(/\\'/g, \"%27\")\r\n .replace(/\\!/g, \"%21\")\r\n .replace(/\\~/g, \"%7E\")\r\n );\r\n};\r\n\r\nexport const dateFormat = (dt: Date, fmt: string) => {\r\n const o:Record<string, number> = {\r\n \"M+\": dt.getMonth() + 1, //月份\r\n \"d+\": dt.getDate(), //日\r\n \"h+\": dt.getHours(), //小时\r\n \"m+\": dt.getMinutes(), //分\r\n \"s+\": dt.getSeconds(), //秒\r\n \"q+\": Math.floor((dt.getMonth() + 3) / 3), //季度\r\n S: dt.getMilliseconds(), //毫秒\r\n };\r\n if (/(y+)/.test(fmt)){\r\n const regx = new RegExp(/(y+)/);\r\n const value = regx.exec(fmt);\r\n let len = 0;\r\n if(value && value.length > 0){\r\n len = value[0].length;\r\n }\r\n fmt = fmt.replace(/(y+)/, dt.getFullYear() + \"\").substring(4 - len);\r\n }\r\n\r\n for (const k in o){\r\n const s:string = \"(\" + k + \")\";\r\n const regx = new RegExp(s);\r\n if(regx.test(fmt)){\r\n const value = regx.exec(fmt);\r\n let len = 0;\r\n if(value && value.length > 0){\r\n len = value[0].length;\r\n }\r\n fmt = fmt.replace(regx, len == 1 ? o[k].toString() : (\"00\" + o[k]).substring(o[k].toString().length))\r\n }\r\n }\r\n return fmt;\r\n}","import md5 from \"js-md5\";\r\nimport CryptoJS from 'crypto-js';\r\nimport { isArray, randomString, urlEncode, urlParamToJson } from \"./utils\";\r\nimport {\r\n ClientGetParams,\r\n ClientPostParams,\r\n CSRFToken,\r\n CurWebsite,\r\n HttpClientOpts,\r\n HttpHeaders,\r\n HttpToken,\r\n ResultModel,\r\n ServerRequestOptions,\r\n ICookies,\r\n IStorage\r\n} from \"./types/http\";\r\nimport { User, USER_TYPE, USER_TYPE_MAP } from \"./types/user\";\r\nimport { logger } from \"./logger\";\r\n\r\n\r\nexport const DEFAULT_LOCALE = 'zh-CN';\r\nexport const DEVICE_ID_KEY = \"_device_id_key\";\r\nexport const CURRENT_WEBSITE_KEY = \"_current_website_key\"\r\n\r\nconst _GET_ERROR = \"Get request error!\"\r\nconst _POST_ERROR = \"Post request error!\";\r\n\r\nexport const COOKIE_NAMES = {\r\n \"IBOOT_DEVICE_ID\": \"dvid\",\r\n \"IBOOT_LANG\": \"lang\",\r\n \"IBOOT_WEBSITE_ID\": \"wid\",\r\n \"IBOOT_WEBSITE_NO\": \"wno\",\r\n \"IBOOT_TOKEN\": \"token\",\r\n \"IBOOT_USER\": \"user\"\r\n}\r\n\r\nconst HEADER_NAMES = {\r\n \"DEVICE_ID\": \"Device-Id\",\r\n \"LANG\": \"Lang\",\r\n \"WEBSITE_ID\": \"Website-Id\",\r\n \"WEBSITE_NO\": \"Website-No\",\r\n}\r\n\r\n\r\nconst getDefaultRequestHeader = (storage: Readonly<IStorage>): HttpHeaders => {\r\n if (!storage.get) {\r\n throw new Error(\"The get method of IStorage has not been implemented.\")\r\n }\r\n const devideId = storage.get(DEVICE_ID_KEY) ?? ''\r\n const json = storage.get(CURRENT_WEBSITE_KEY);\r\n const curWebsite: CurWebsite | null = json != null ? JSON.parse(json) : null;\r\n const header: HttpHeaders = {}\r\n if (devideId.length > 0) {\r\n header['Device-Id'] = devideId\r\n }\r\n if (curWebsite) {\r\n header['Lang'] = curWebsite.language;\r\n if (curWebsite.websiteId) {\r\n header['Website-Id'] = curWebsite.websiteId;\r\n }\r\n if (curWebsite.websiteNo) {\r\n header['Website-No'] = curWebsite.websiteNo\r\n }\r\n }\r\n return header;\r\n};\r\n\r\n\r\nexport const setDefaultRequestHeader = ({ deviceId, website }: Readonly<{ deviceId: string, website?: CurWebsite }>, storage: IStorage): void => {\r\n if (!storage.set) {\r\n throw new Error(\"The set method of IStorage has not been implemented.\")\r\n }\r\n storage.set(DEVICE_ID_KEY, deviceId);\r\n if (website) {\r\n storage.set(CURRENT_WEBSITE_KEY, JSON.stringify(website));\r\n }\r\n}\r\n\r\nexport const get = async <T>(url: string, opts?: ClientGetParams): Promise<ResultModel<T>> => {\r\n if (opts?.data) {\r\n const params = new URLSearchParams(opts.data);\r\n if (url.indexOf(\"?\") != -1) {\r\n url += `&${params}`\r\n } else {\r\n url += `?${params}`\r\n }\r\n }\r\n const headers: Record<string, string> = (opts && opts.storage && opts.storage.get) ? getDefaultRequestHeader(opts.storage) : {}\r\n const heads = opts?.headers;\r\n if (heads) {\r\n for (const field in heads) {\r\n const value = heads[field];\r\n if (value) {\r\n headers[field] = value;\r\n }\r\n }\r\n }\r\n logger.info({\r\n \"url\": url,\r\n \"headers\": headers,\r\n }, \"GET\")\r\n const res = await fetch(url, {\r\n method: 'GET',\r\n headers: headers,\r\n cache: opts?.useCache ? 'force-cache' : 'default'\r\n });\r\n\r\n if (res.ok) {\r\n const headersMap = Object.fromEntries(res.headers.entries());\r\n const result = { ...await res.json(), headers: headersMap };\r\n logger.debug(result, \"GET_RESULT\")\r\n return result\r\n }\r\n const msg = {\r\n code: res.status,\r\n success: false,\r\n msg: res.statusText\r\n }\r\n logger.error(msg);\r\n return msg;\r\n}\r\n\r\nexport const post = async <T>(url: string, opts?: ClientPostParams): Promise<ResultModel<T>> => {\r\n const data = opts?.data ?? {};\r\n const heads = opts?.headers;\r\n let body: string | FormData;\r\n const defaultHeads = (opts && opts.storage && opts.storage.get) ? getDefaultRequestHeader(opts.storage) : {}\r\n const proxyHeaders = new Headers(defaultHeads);\r\n if (!(data instanceof FormData)) {\r\n body = JSON.stringify(data);\r\n proxyHeaders.set('Content-Type', 'application/json');\r\n } else {\r\n body = data;\r\n }\r\n if (heads) {\r\n for (let field in heads) {\r\n const value = heads[field];\r\n if (value) {\r\n proxyHeaders.set(field, value);\r\n }\r\n }\r\n }\r\n logger.info({\r\n \"url\": url,\r\n \"headers\": proxyHeaders,\r\n }, \"POST\")\r\n const res = await fetch(url, {\r\n method: 'POST',\r\n headers: proxyHeaders,\r\n body: body,\r\n });\r\n if (res.ok) {\r\n const headersMap = Object.fromEntries(res.headers.entries());\r\n const result = { ...await res.json(), headers: headersMap };\r\n logger.debug(result, \"POST_RESULT\")\r\n return result\r\n }\r\n const msg = {\r\n code: res.status,\r\n success: false,\r\n msg: res.statusText,\r\n }\r\n logger.error(msg);\r\n return msg;\r\n}\r\n\r\nexport const iGet = async <T>(url: string, opts?: ClientGetParams): Promise<T | undefined> => {\r\n const res = await get<T>(url, opts);\r\n if (res.success) {\r\n return res.data as T;\r\n }\r\n if (opts?.showError) {\r\n opts.showError(res.msg ?? _GET_ERROR);\r\n return;\r\n }\r\n throw Error(res.msg ?? _GET_ERROR)\r\n}\r\n\r\nexport const iPost = async <T>(url: string, opts?: ClientPostParams): Promise<T | undefined> => {\r\n const res = await post<T>(url, opts);\r\n if (res.success) {\r\n return res.data;\r\n }\r\n if (opts?.showError) {\r\n opts.showError(res.msg ?? _POST_ERROR);\r\n return;\r\n }\r\n throw Error(res.msg ?? _POST_ERROR)\r\n}\r\n\r\nexport const iPostSuccess = async (url: string, opts?: ClientPostParams): Promise<boolean> => {\r\n const res = await post(url, opts);\r\n if (res.success) {\r\n if (opts?.showSuccess) {\r\n opts.showSuccess(res.msg ?? 'SUCCESS')\r\n }\r\n return true;\r\n }\r\n if (opts?.showError) {\r\n opts.showError(res.msg ?? _POST_ERROR);\r\n }\r\n return false;\r\n}\r\n\r\nexport const getHttpOpts = (storage: IStorage): HttpClientOpts => {\r\n if (storage.get) {\r\n const deviceId = storage.get(HEADER_NAMES.DEVICE_ID);\r\n const lang = storage.get(HEADER_NAMES.LANG);\r\n const websiteId = storage.get(HEADER_NAMES.WEBSITE_ID);\r\n const websiteNo = storage.get(HEADER_NAMES.WEBSITE_NO);\r\n const result: HttpClientOpts = {}\r\n if (deviceId && deviceId.length > 0) {\r\n result.deviceId = deviceId;\r\n }\r\n if (lang && lang.length > 0) {\r\n result.lang = lang\r\n }\r\n if (websiteId && websiteId.length > 0) {\r\n result.websiteId = websiteId\r\n }\r\n if (websiteNo && websiteNo.length > 0) {\r\n result.websiteNo = websiteNo\r\n }\r\n return result;\r\n }\r\n throw new Error(\"The set method of IStorage has not been implemented.\")\r\n}\r\n\r\nexport const getLoginUser = (cookies: ICookies): User | undefined => {\r\n if (cookies.get) {\r\n const userjson = cookies.get(COOKIE_NAMES.IBOOT_USER)\r\n if (userjson && userjson.length > 0) {\r\n return JSON.parse(userjson);\r\n }\r\n }\r\n return undefined\r\n}\r\n\r\nexport const getToken = (cookies: ICookies): HttpToken | undefined => {\r\n if (cookies.get) {\r\n const userjson = cookies.get(COOKIE_NAMES.IBOOT_USER);\r\n if (userjson && userjson.length > 0) {\r\n const user = JSON.parse(userjson);\r\n const username = user.username;\r\n const utype = user.userType.toString();\r\n const token = cookies.get(COOKIE_NAMES.IBOOT_TOKEN);\r\n if (token) {\r\n return {\r\n \"username\": username,\r\n \"utype\": utype,\r\n \"token\": token\r\n }\r\n }\r\n }\r\n }\r\n return undefined\r\n}\r\n\r\nexport const setToken = (data: User & { token: string }, cookies: ICookies): void => {\r\n const { id, name, username, nickname, headImg, token, lastLoginTime, deviceId, userType, mustChangePwd } = data;\r\n const loginUser: User = {\r\n id: id,\r\n name: name,\r\n username: username,\r\n nickname: nickname || name,\r\n headImg: headImg,\r\n lastLoginTime: lastLoginTime,\r\n deviceId: deviceId,\r\n userType: userType,\r\n accountType: 0,\r\n needToReview: false,\r\n socketOnline: false,\r\n mustChangePwd: mustChangePwd\r\n };\r\n if (!cookies.set) {\r\n throw new Error('cookies set function is undefined')\r\n }\r\n cookies.set(COOKIE_NAMES.IBOOT_TOKEN, token, {\r\n path: '/',\r\n secure: process.env.APP_ENV === 'production',\r\n httpOnly: true,\r\n sameSite: 'strict'\r\n });\r\n cookies.set(COOKIE_NAMES.IBOOT_USER, JSON.stringify(loginUser))\r\n}\r\n\r\nexport const cleanToken = (cookies: ICookies): void => {\r\n if (!cookies.set) {\r\n throw new Error('cookies set function is undefined')\r\n }\r\n cookies.set(COOKIE_NAMES.IBOOT_TOKEN, '', {\r\n maxAge: -1, //设置为 -1表示立即过期\r\n httpOnly: true,\r\n path: '/',\r\n });\r\n cookies.set(COOKIE_NAMES.IBOOT_USER, '', {\r\n maxAge: -1, //设置为 -1表示立即过期\r\n httpOnly: true,\r\n path: '/',\r\n });\r\n if (!cookies.delete) {\r\n throw new Error('cookies delete function is undefined')\r\n }\r\n cookies.delete(COOKIE_NAMES.IBOOT_TOKEN);\r\n cookies.delete(COOKIE_NAMES.IBOOT_USER);\r\n}\r\n\r\nexport class HttpClient {\r\n private readonly baseUrl: string;\r\n private readonly helloMethod: string;\r\n private readonly apiKey: string;\r\n private readonly userType: USER_TYPE;\r\n private readonly userFrom: string;\r\n private readonly deviceId: string;\r\n private readonly version: string = '1';\r\n private readonly lang: string;\r\n private readonly websiteId?: string;\r\n private readonly websiteNo?: string;\r\n constructor(opts: Readonly<HttpClientOpts>) {\r\n const isProduction = process.env.APP_ENV === 'production';\r\n if (!isProduction) {\r\n logger.warn(\"This is currently a development environment!\")\r\n }\r\n this.baseUrl = process.env.APP_BASEURL!;\r\n this.apiKey = process.env.APP_APIKEY!;\r\n this.userFrom = process.env.APP_USERFROM ?? '1';\r\n\r\n this.helloMethod = opts.helloURL ?? ''\r\n this.userType = opts.userType ?? USER_TYPE_MAP.TYPE_MGT;\r\n this.deviceId = opts.deviceId ?? randomString(10);\r\n this.lang = opts.lang ?? DEFAULT_LOCALE;\r\n this.websiteId = opts.websiteId\r\n this.websiteNo = opts.websiteNo\r\n }\r\n\r\n encrypt(data: string) {\r\n const key = CryptoJS.enc.Utf8.parse(this.apiKey);\r\n return CryptoJS.AES.encrypt(data, key).toString();\r\n }\r\n\r\n decrypt(data: string) {\r\n const key = CryptoJS.enc.Utf8.parse(this.apiKey);\r\n return CryptoJS.AES.decrypt(data, key, {\r\n mode: CryptoJS.mode.ECB,\r\n }).toString(CryptoJS.enc.Utf8);\r\n }\r\n\r\n //eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n private convertUrlParameter(data: Record<string, any>): string {\r\n const p: string[] = [];\r\n for (const o in data) {\r\n let v = data[o];\r\n if (v && typeof v === \"string\") {\r\n v = v.trim();\r\n } else if (v && typeof v === \"object\") {\r\n if (isArray(v)) {\r\n if (v.length === 0) {\r\n continue;\r\n }\r\n for (let i = 0; i < v.length; i++) {\r\n const arr_item = v[i];\r\n for (const item_field in arr_item) {\r\n const item_field_value = arr_item[item_field] ?? undefined;\r\n if (item_field_value) {\r\n if (typeof item_field_value === \"object\") {\r\n if (isArray(item_field_value)) {\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n item_field_value.forEach((item1: any, index: number) => {\r\n if (item1) {\r\n for (const f in item1) {\r\n const v = item1[f];\r\n if (v && v.toString().length > 0) {\r\n const s = `[${i.toString()}].${item_field + `[${index.toString()}].${f}`}=${urlEncode(v)}`;\r\n p.push(o + s);\r\n }\r\n }\r\n }\r\n });\r\n }\r\n } else if (item_field_value.toString().length > 0) {\r\n const s = `[${i.toString()}].${item_field}=${urlEncode(item_field_value.toString())}`;\r\n p.push(o + s);\r\n }\r\n }\r\n }\r\n }\r\n } else {\r\n for (const obj in v) {\r\n const oValue = v[obj];\r\n if (oValue != null && oValue != \"\" && oValue.length != 0) {\r\n const s = `.${obj}=${urlEncode(oValue)}`;\r\n p.push(o + s);\r\n }\r\n }\r\n }\r\n continue;\r\n } else if (v && typeof v === \"function\") {\r\n v = null;\r\n }\r\n\r\n if (v != null && v != \"\" && v.length != 0) {\r\n p.push(o + \"=\" + urlEncode(v));\r\n }\r\n }\r\n return (p && p.join(\"&\"));\r\n }\r\n\r\n private async sign(data: Record<string, object | string>): Promise<string> {\r\n //由后台分配\r\n const _apiKey = \"&key=\" + (await this.helloIboot());\r\n const arr: string[] = [];\r\n for (const o in data) {\r\n arr.push(o);\r\n }\r\n arr.sort((a: string, b: string) => {\r\n return a.toLowerCase().localeCompare(b.toLowerCase());\r\n });\r\n const res: string[] = [];\r\n arr.forEach((v: string) => {\r\n let value: object | string = data[v];\r\n if (typeof value === \"object\") {\r\n value = JSON.stringify(value);\r\n }\r\n res.push(v + \"=\" + value);\r\n });\r\n const paramsStr: string = res.join(\"&\");\r\n const str = md5.md5((paramsStr + _apiKey).toLocaleUpperCase());\r\n const logInfo = {\r\n params: paramsStr,\r\n md5: str\r\n }\r\n logger.debug(logInfo, \"API_SIGN\")\r\n return str;\r\n }\r\n\r\n //eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n private assemblyParameter(data?: Record<string, any>, username?: string): Record<string, any> {\r\n const params = data ?? {};\r\n params['timestamp'] = Date.now() + '';\r\n params['echostr'] = randomString(10);\r\n params['version'] = this.version;\r\n params['deviceId'] = this.deviceId;\r\n params['webid'] = this.websiteId;\r\n params['apiKey'] = this.apiKey;\r\n if (username && username.length > 0) {\r\n params['username'] = username;\r\n }\r\n return params;\r\n }\r\n\r\n private async assemblyHeader({ urlParams, token }: Readonly<{ urlParams: string, token?: Readonly<HttpToken> }>) {\r\n const h: Record<string, string> = {\r\n 'Content-Type': 'application/x-www-form-urlencoded',\r\n 'Res-Type': 'json',\r\n 'Device-Id': this.deviceId,\r\n 'User-Type': token?.utype.toString() ?? this.userType.toString(),\r\n 'User-From': this.userFrom,\r\n 'Api-Key': this.apiKey\r\n }\r\n if (this.lang && this.lang.length > 0) {\r\n h['Lang'] = this.lang\r\n }\r\n if (this.websiteId && this.websiteId.length > 0) {\r\n h['Web-Id'] = this.websiteId\r\n }\r\n if (this.websiteNo && this.websiteNo.length > 0) {\r\n h['Web-No'] = this.websiteNo\r\n }\r\n if (token) {\r\n if (token.token && token.token.length > 0 && token.username && token.username.length > 0) {\r\n h['Authorization'] = token.token;\r\n h['Username'] = token.username;\r\n }\r\n if (token.xcsrf) {\r\n h[token.xcsrf.csrfHeader] = token.xcsrf.csrfToken;\r\n }\r\n }\r\n const data = urlParamToJson(urlParams);\r\n const sign = await this.sign(data);\r\n h['Sign'] = sign\r\n return h;\r\n }\r\n\r\n private async helloIboot(): Promise<string> {\r\n if (this.helloMethod.length <= 0) {\r\n return this.apiKey;\r\n }\r\n const api = this.getApiUrl(this.helloMethod);\r\n const h = {\r\n 'Content-Type': 'application/x-www-form-urlencoded',\r\n 'Res-Type': 'json',\r\n 'Api-Key': this.apiKey\r\n }\r\n const logInfo = {\r\n \"url\": api,\r\n \"headers\": h\r\n }\r\n logger.debug(logInfo, \"HELLO\");\r\n const res = await fetch(api, {\r\n method: 'GET',\r\n headers: h,\r\n credentials: 'include',\r\n cache: 'force-cache'\r\n });\r\n if (res.ok) {\r\n const result = await res.json();\r\n logger.debug(result.data, 'HELLO RESULT')\r\n return result.data;\r\n }\r\n throw new Error('hello iBoot error!')\r\n }\r\n\r\n private getApiUrl(url: string): string {\r\n return `${this.baseUrl}/${url}`;\r\n }\r\n\r\n async csrf(): Promise<string | undefined> {\r\n const res = await this.get<CSRFToken>({\r\n url: 'guest/csrf'\r\n });\r\n if (res.success) {\r\n const data = res.data;\r\n if (data) {\r\n return data[\"csrfToken\"].toString();\r\n }\r\n }\r\n return undefined;\r\n }\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n async get<T>({ url, data, token, cache = 'default' }: Readonly<ServerRequestOptions>): Promise<ResultModel<T>> {\r\n const params = this.assemblyParameter(data);\r\n const urlParams = this.convertUrlParameter(params);\r\n const headers = await this.assemblyHeader({ \"urlParams\": urlParams, \"token\": token });\r\n const api = `${this.getApiUrl(url)}?${urlParams.toString()}`\r\n const logInfo = {\r\n \"url\": api,\r\n \"headers\": headers\r\n }\r\n logger.info(logInfo, \"GET\");\r\n const res = await fetch(api, {\r\n \"method\": 'GET',\r\n \"headers\": headers,\r\n \"credentials\": 'include',\r\n \"cache\": cache\r\n });\r\n if (res.ok) {\r\n const headersMap = Object.fromEntries(res.headers.entries());\r\n const result = { ...await res.json(), headers: headersMap };\r\n logger.debug(result, \"GET_RESULT\")\r\n return result;\r\n }\r\n const msg = {\r\n code: res.status,\r\n success: false,\r\n msg: res.statusText\r\n }\r\n logger.error(msg);\r\n return msg;\r\n }\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n async post<T>({ url, data, token, cache = \"default\" }: Readonly<ServerRequestOptions>): Promise<ResultModel<T>> {\r\n data = data ? { ...data } : {}\r\n const buffer = data.buffer ?? undefined;\r\n const boundary = data.boundary ?? undefined;\r\n if (buffer) {\r\n delete data.buffer;\r\n }\r\n if (boundary) {\r\n delete data.boundary;\r\n }\r\n const params = this.assemblyParameter(data);\r\n const urlParams = this.convertUrlParameter(params);\r\n const headers = await this.assemblyHeader({ \"urlParams\": urlParams, \"token\": token });\r\n if (buffer && boundary) {\r\n headers['Content-Type'] = `multipart/form-data; boundary=${boundary}`;\r\n }\r\n const api = this.getApiUrl(url);\r\n const logInfo = {\r\n \"url\": api,\r\n \"headers\": headers,\r\n \"params\": params\r\n }\r\n logger.info(logInfo, \"POST\");\r\n const urls = buffer ? `${api}?${urlParams}` : api;\r\n const res = await fetch(urls, {\r\n \"method\": 'POST',\r\n \"headers\": headers,\r\n \"body\": buffer ? buffer : urlParams.toString(),\r\n \"credentials\": 'include',\r\n \"cache\": cache\r\n });\r\n if (res.ok) {\r\n const headersMap = Object.fromEntries(res.headers.entries());\r\n const result = { ...await res.json(), headers: headersMap };\r\n logger.debug(result, \"POST_RESULT\");\r\n return result;\r\n }\r\n const msg = {\r\n code: res.status,\r\n success: false,\r\n msg: res.statusText\r\n }\r\n logger.error(msg);\r\n return msg;\r\n }\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n async stream({ url, data, token }: Readonly<Omit<ServerRequestOptions, 'cache'>>): Promise<Response> {\r\n data = data ? { ...data } : {}\r\n const buffer = data.buffer ?? undefined;\r\n const boundary = data.boundary ?? undefined;\r\n if (buffer) {\r\n delete data.buffer;\r\n }\r\n if (boundary) {\r\n delete data.boundary;\r\n }\r\n const params = this.assemblyParameter(data);\r\n const urlParams = this.convertUrlParameter(params); //new URLSearchParams(params);\r\n\r\n const headers = await this.assemblyHeader({ \"urlParams\": urlParams, \"token\": token });\r\n if (buffer && boundary) {\r\n headers['Content-Type'] = `multipart/form-data; boundary=${boundary}`;\r\n }\r\n headers['Connection'] = 'keep-alive';\r\n headers['X-Accel-Buffering'] = 'no'; //防止 Nginx 缓存\r\n headers['Cache-Control'] = 'no-cache';\r\n const api = this.getApiUrl(url)\r\n try {\r\n const url = buffer ? `${api}?${urlParams}` : api;\r\n const logInfo = {\r\n \"url\": api,\r\n \"headers\": headers,\r\n \"params\": params\r\n }\r\n logger.info(logInfo, \"STREAM\");\r\n const res = await fetch(url, {\r\n method: 'POST',\r\n headers: headers,\r\n body: buffer ? buffer : urlParams.toString(),\r\n credentials: 'include'\r\n });\r\n\r\n if (!res.ok) {\r\n throw new Error(`HTTP error! status: ${res.status}`);\r\n }\r\n if (!res.body) {\r\n throw new Error('No response body');\r\n }\r\n const headersMap = Object.fromEntries(res.headers.entries());\r\n return new Response(res.body, {\r\n headers: headersMap\r\n });\r\n } catch (e) {\r\n throw e;\r\n }\r\n }\r\n}"],"names":["ACCOUNT_TYPE_MAP","USER_TYPE_MAP","USER_FORM_MAP","USER_SEX_MAP","stream","PinoPretty","logger","pino","isArray","obj","randomString","len","l","$chars","maxPos","pwd","i","urlParamToJson","urlQueryParams","exclude","result","item","arr","urlEncode","value","dateFormat","dt","fmt","o","k","regx","DEFAULT_LOCALE","DEVICE_ID_KEY","CURRENT_WEBSITE_KEY","_GET_ERROR","_POST_ERROR","COOKIE_NAMES","HEADER_NAMES","getDefaultRequestHeader","storage","devideId","json","curWebsite","header","setDefaultRequestHeader","deviceId","website","get","url","opts","params","headers","heads","field","res","headersMap","msg","post","data","body","defaultHeads","proxyHeaders","iGet","iPost","iPostSuccess","getHttpOpts","lang","websiteId","websiteNo","getLoginUser","cookies","userjson","getToken","user","username","utype","token","setToken","id","name","nickname","headImg","lastLoginTime","userType","mustChangePwd","loginUser","cleanToken","HttpClient","key","CryptoJS","p","v","arr_item","item_field","item_field_value","item1","index","f","s","oValue","_apiKey","a","b","paramsStr","str","md5","logInfo","urlParams","h","sign","api","cache","buffer","boundary","urls","e"],"mappings":"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"}
1
+ {"version":3,"file":"iboot-http-client.cjs.js","sources":["../src/types/user.ts","../src/logger.ts","../src/utils.ts","../src/http-client.ts"],"sourcesContent":["export const ACCOUNT_TYPE_MAP = {\r\n GENERAL : 0,\r\n PHONE : 1,\r\n EMAIL : 2\r\n}\r\n\r\nexport const USER_TYPE_MAP = {\r\n TYPE_MGT : 0,\r\n TYPE_C : 1,\r\n TYPE_B : 2\r\n}\r\n\r\nexport const USER_FORM_MAP = {\r\n FROM_WEB : 1,\r\n FROM_PC : 2,\r\n FROM_WX_MINI_PRO : 3,\r\n FROM_WX_PLU : 4,\r\n FROM_WX_E : 5,\r\n FROM_APP : 6,\r\n FROM_DEVICE : 7\r\n}\r\n\r\nexport const USER_SEX_MAP = {\r\n unknown:0,\r\n male:1,\r\n female:2,\r\n}\r\n\r\nexport type ACCOUNT_TYPE = typeof ACCOUNT_TYPE_MAP[keyof typeof ACCOUNT_TYPE_MAP];\r\nexport type USER_TYPE = typeof USER_TYPE_MAP[keyof typeof USER_TYPE_MAP];\r\nexport type USER_FORM = typeof USER_FORM_MAP[keyof typeof USER_FORM_MAP];\r\nexport type USER_SEX = typeof USER_SEX_MAP[keyof typeof USER_SEX_MAP];\r\n\r\n// User interface\r\nexport interface User {\r\n id: string;\r\n name: string;\r\n userType: USER_TYPE;\r\n username?: string;\r\n nickname?: string;\r\n sex?: USER_SEX;\r\n headImg?: string;\r\n lastLoginTime?: string;\r\n tokenExpired?: string;\r\n deviceId?: string;\r\n status?: number;\r\n accountType?: number;\r\n enabled?: boolean;\r\n userFrom?: USER_FORM;\r\n needToReview?: boolean;\r\n socketOnline?: boolean;\r\n createTime?: string;\r\n mustChangePwd?: boolean;\r\n}","import pino from \"pino\";\r\nimport PinoPretty from \"pino-pretty\";\r\n// import koffi from 'koffi';\r\n\r\n// if (typeof window === 'undefined' && process.platform === 'win32') {\r\n// try {\r\n// const CP_UTF8 = 65001;\r\n// const kernel32 = koffi.load('Kernel32');\r\n// const setConsoleOutputCP = kernel32.func('SetConsoleOutputCP', 'bool', ['int']);\r\n// const setConsoleCP = kernel32.func('SetConsoleCP', 'bool', ['int']);\r\n// setConsoleOutputCP(CP_UTF8);\r\n// setConsoleCP(CP_UTF8);\r\n// } catch (e) {\r\n// console.log(e);\r\n// }\r\n// }\r\n\r\n// export const logger = pino({\r\n// name: process.env.APP_NAME ?? 'iBoot',\r\n// level: process.env.NODE_ENV !== 'production' ? 'debug' : 'info',\r\n// nestedKey: 'payload',\r\n// transport: {\r\n// target: 'pino-pretty',\r\n// options: {\r\n// colorize: true,\r\n// translateTime: 'SYS:yyyy-mm-dd HH:MM:ss',\r\n// ignore: 'pid,hostname',\r\n// messageFormat: '{msg}',\r\n// singleLine: true,\r\n// },\r\n// }\r\n// });\r\n\r\nconst stream = PinoPretty({\r\n colorize: true,\r\n destination: process.stdout,\r\n translateTime: 'SYS:yyyy-mm-dd HH:MM:ss',\r\n ignore: 'pid,hostname',\r\n messageFormat: '{msg}',\r\n singleLine: true,\r\n});\r\n\r\nexport const logger = pino({\r\n name: process.env.APP_NAME ?? 'iBoot',\r\n level: process.env.APP_ENV === 'production' ? 'info' : 'debug',\r\n nestedKey: 'payload'\r\n}, stream);","export const isArray = (obj: unknown) => {\r\n return (\r\n Array.isArray(obj) ||\r\n (typeof obj === \"object\" &&\r\n Object.prototype.toString.call(obj) === \"[object Array]\")\r\n );\r\n};\r\n\r\n/**\r\n * 生成指定长度的随机串\r\n * @param {Object} len\r\n */\r\nexport const randomString = (len: number) => {\r\n const l = len || 32;\r\n const $chars = \"ABCDEFGHJKMNPQRSTWXYZabcdefhijkmnprstwxyz2345678\";\r\n const maxPos = $chars.length;\r\n let pwd = \"\";\r\n for (let i = 0; i < l; i++) {\r\n pwd += $chars.charAt(Math.floor(Math.random() * maxPos));\r\n }\r\n return pwd;\r\n};\r\n\r\nexport const urlParamToJson = (urlQueryParams: string, exclude?: string[]): Record<string, string> => {\r\n const result: Record<string, string> = {};\r\n const strs = urlQueryParams.split(\"&\");\r\n strs.forEach((item) => {\r\n const arr = item.split(\"=\");\r\n if (arr[1]) {\r\n if (!exclude || exclude.indexOf(arr[0]) == -1) {\r\n result[arr[0]] = arr[1];\r\n }\r\n }\r\n });\r\n return result;\r\n};\r\n\r\nexport const urlEncode = (value: string | null | undefined): string => {\r\n if (!value || value == \"\" || value.length == 0) {\r\n return \"\";\r\n }\r\n return (\r\n encodeURIComponent(value)\r\n // .replace(/%20/g, '+')\r\n // .replace(/%2B/g, '\\\\+')\r\n .replace(/\\(/g, \"%28\")\r\n .replace(/\\)/g, \"%29\")\r\n .replace(/\\'/g, \"%27\")\r\n .replace(/\\!/g, \"%21\")\r\n .replace(/\\~/g, \"%7E\")\r\n );\r\n};\r\n\r\nexport const dateFormat = (dt: Date, fmt: string) => {\r\n const o:Record<string, number> = {\r\n \"M+\": dt.getMonth() + 1, //月份\r\n \"d+\": dt.getDate(), //日\r\n \"h+\": dt.getHours(), //小时\r\n \"m+\": dt.getMinutes(), //分\r\n \"s+\": dt.getSeconds(), //秒\r\n \"q+\": Math.floor((dt.getMonth() + 3) / 3), //季度\r\n S: dt.getMilliseconds(), //毫秒\r\n };\r\n if (/(y+)/.test(fmt)){\r\n const regx = new RegExp(/(y+)/);\r\n const value = regx.exec(fmt);\r\n let len = 0;\r\n if(value && value.length > 0){\r\n len = value[0].length;\r\n }\r\n fmt = fmt.replace(/(y+)/, dt.getFullYear() + \"\").substring(4 - len);\r\n }\r\n\r\n for (const k in o){\r\n const s:string = \"(\" + k + \")\";\r\n const regx = new RegExp(s);\r\n if(regx.test(fmt)){\r\n const value = regx.exec(fmt);\r\n let len = 0;\r\n if(value && value.length > 0){\r\n len = value[0].length;\r\n }\r\n fmt = fmt.replace(regx, len == 1 ? o[k].toString() : (\"00\" + o[k]).substring(o[k].toString().length))\r\n }\r\n }\r\n return fmt;\r\n}","import md5 from \"js-md5\";\r\nimport CryptoJS from 'crypto-js';\r\nimport { isArray, randomString, urlEncode, urlParamToJson } from \"./utils\";\r\nimport {\r\n ClientGetParams,\r\n ClientPostParams,\r\n CSRFToken,\r\n CurWebsite,\r\n HttpClientOpts,\r\n HttpHeaders,\r\n HttpToken,\r\n ResultModel,\r\n ServerRequestOptions,\r\n ICookies,\r\n IStorage\r\n} from \"./types/http\";\r\nimport { User, USER_TYPE, USER_TYPE_MAP } from \"./types/user\";\r\nimport { logger } from \"./logger\";\r\n\r\n\r\nexport const DEFAULT_LOCALE = 'zh-CN';\r\nexport const DEVICE_ID_KEY = \"_device_id_key\";\r\nexport const CURRENT_WEBSITE_KEY = \"_current_website_key\"\r\n\r\nconst _GET_ERROR = \"Get request error!\"\r\nconst _POST_ERROR = \"Post request error!\";\r\n\r\nexport const COOKIE_NAMES = {\r\n \"IBOOT_DEVICE_ID\": \"dvid\",\r\n \"IBOOT_LANG\": \"lang\",\r\n \"IBOOT_WEBSITE_ID\": \"wid\",\r\n \"IBOOT_WEBSITE_NO\": \"wno\",\r\n \"IBOOT_TOKEN\": \"token\",\r\n \"IBOOT_USER\": \"user\"\r\n}\r\n\r\nexport const HEADER_NAMES = {\r\n \"DEVICE_ID\": \"Device-Id\",\r\n \"LANG\": \"Lang\",\r\n \"WEBSITE_ID\": \"Website-Id\",\r\n \"WEBSITE_NO\": \"Website-No\",\r\n}\r\n\r\n\r\nconst getDefaultRequestHeader = (storage: Readonly<IStorage>): HttpHeaders => {\r\n if (!storage.get) {\r\n throw new Error(\"The get method of IStorage has not been implemented.\")\r\n }\r\n const devideId = storage.get(DEVICE_ID_KEY) ?? ''\r\n const json = storage.get(CURRENT_WEBSITE_KEY);\r\n const curWebsite: CurWebsite | null = json != null ? JSON.parse(json) : null;\r\n const header: HttpHeaders = {}\r\n if (devideId.length > 0) {\r\n header['Device-Id'] = devideId\r\n }\r\n if (curWebsite) {\r\n header['Lang'] = curWebsite.language;\r\n if (curWebsite.websiteId) {\r\n header['Website-Id'] = curWebsite.websiteId;\r\n }\r\n if (curWebsite.websiteNo) {\r\n header['Website-No'] = curWebsite.websiteNo\r\n }\r\n }\r\n return header;\r\n};\r\n\r\n\r\nexport const setDefaultRequestHeader = ({ deviceId, website }: Readonly<{ deviceId: string, website?: CurWebsite }>, storage: IStorage): void => {\r\n if (!storage.set) {\r\n throw new Error(\"The set method of IStorage has not been implemented.\")\r\n }\r\n storage.set(DEVICE_ID_KEY, deviceId);\r\n if (website) {\r\n storage.set(CURRENT_WEBSITE_KEY, JSON.stringify(website));\r\n }\r\n}\r\n\r\nexport const get = async <T>(url: string, opts?: ClientGetParams): Promise<ResultModel<T>> => {\r\n if (opts?.data) {\r\n const params = new URLSearchParams(opts.data);\r\n if (url.indexOf(\"?\") != -1) {\r\n url += `&${params}`\r\n } else {\r\n url += `?${params}`\r\n }\r\n }\r\n const headers: Record<string, string> = (opts && opts.storage && opts.storage.get) ? getDefaultRequestHeader(opts.storage) : {}\r\n const heads = opts?.headers;\r\n if (heads) {\r\n for (const field in heads) {\r\n const value = heads[field];\r\n if (value) {\r\n headers[field] = value;\r\n }\r\n }\r\n }\r\n logger.info({\r\n \"url\": url,\r\n \"headers\": headers,\r\n }, \"GET\")\r\n const res = await fetch(url, {\r\n method: 'GET',\r\n headers: headers,\r\n cache: opts?.useCache ? 'force-cache' : 'default'\r\n });\r\n\r\n if (res.ok) {\r\n const headersMap = Object.fromEntries(res.headers.entries());\r\n const result = { ...await res.json(), headers: headersMap };\r\n logger.debug(result, \"GET_RESULT\")\r\n return result\r\n }\r\n const msg = {\r\n code: res.status,\r\n success: false,\r\n msg: res.statusText\r\n }\r\n logger.error(msg);\r\n return msg;\r\n}\r\n\r\nexport const post = async <T>(url: string, opts?: ClientPostParams): Promise<ResultModel<T>> => {\r\n const data = opts?.data ?? {};\r\n const heads = opts?.headers;\r\n let body: string | FormData;\r\n const defaultHeads = (opts && opts.storage && opts.storage.get) ? getDefaultRequestHeader(opts.storage) : {}\r\n const proxyHeaders = new Headers(defaultHeads);\r\n if (!(data instanceof FormData)) {\r\n body = JSON.stringify(data);\r\n proxyHeaders.set('Content-Type', 'application/json');\r\n } else {\r\n body = data;\r\n }\r\n if (heads) {\r\n for (let field in heads) {\r\n const value = heads[field];\r\n if (value) {\r\n proxyHeaders.set(field, value);\r\n }\r\n }\r\n }\r\n logger.info({\r\n \"url\": url,\r\n \"headers\": proxyHeaders,\r\n }, \"POST\")\r\n const res = await fetch(url, {\r\n method: 'POST',\r\n headers: proxyHeaders,\r\n body: body,\r\n });\r\n if (res.ok) {\r\n const headersMap = Object.fromEntries(res.headers.entries());\r\n const result = { ...await res.json(), headers: headersMap };\r\n logger.debug(result, \"POST_RESULT\")\r\n return result\r\n }\r\n const msg = {\r\n code: res.status,\r\n success: false,\r\n msg: res.statusText,\r\n }\r\n logger.error(msg);\r\n return msg;\r\n}\r\n\r\nexport const iGet = async <T>(url: string, opts?: ClientGetParams): Promise<T | undefined> => {\r\n const res = await get<T>(url, opts);\r\n if (res.success) {\r\n return res.data as T;\r\n }\r\n if (opts?.showError) {\r\n opts.showError(res.msg ?? _GET_ERROR);\r\n return;\r\n }\r\n throw Error(res.msg ?? _GET_ERROR)\r\n}\r\n\r\nexport const iPost = async <T>(url: string, opts?: ClientPostParams): Promise<T | undefined> => {\r\n const res = await post<T>(url, opts);\r\n if (res.success) {\r\n return res.data;\r\n }\r\n if (opts?.showError) {\r\n opts.showError(res.msg ?? _POST_ERROR);\r\n return;\r\n }\r\n throw Error(res.msg ?? _POST_ERROR)\r\n}\r\n\r\nexport const iPostSuccess = async (url: string, opts?: ClientPostParams): Promise<boolean> => {\r\n const res = await post(url, opts);\r\n if (res.success) {\r\n if (opts?.showSuccess) {\r\n opts.showSuccess(res.msg ?? 'SUCCESS')\r\n }\r\n return true;\r\n }\r\n if (opts?.showError) {\r\n opts.showError(res.msg ?? _POST_ERROR);\r\n }\r\n return false;\r\n}\r\n\r\nexport const getHttpOpts = (storage: IStorage): HttpClientOpts => {\r\n if (storage.get) {\r\n const deviceId = storage.get(HEADER_NAMES.DEVICE_ID);\r\n const lang = storage.get(HEADER_NAMES.LANG);\r\n const websiteId = storage.get(HEADER_NAMES.WEBSITE_ID);\r\n const websiteNo = storage.get(HEADER_NAMES.WEBSITE_NO);\r\n const result: HttpClientOpts = {}\r\n if (deviceId && deviceId.length > 0) {\r\n result.deviceId = deviceId;\r\n }\r\n if (lang && lang.length > 0) {\r\n result.lang = lang\r\n }\r\n if (websiteId && websiteId.length > 0) {\r\n result.websiteId = websiteId\r\n }\r\n if (websiteNo && websiteNo.length > 0) {\r\n result.websiteNo = websiteNo\r\n }\r\n return result;\r\n }\r\n throw new Error(\"The set method of IStorage has not been implemented.\")\r\n}\r\n\r\nexport const getLoginUser = (cookies: ICookies): User | undefined => {\r\n if (cookies.get) {\r\n const userjson = cookies.get(COOKIE_NAMES.IBOOT_USER)\r\n if (userjson && userjson.length > 0) {\r\n return JSON.parse(userjson);\r\n }\r\n }\r\n return undefined\r\n}\r\n\r\nexport const getToken = (cookies: ICookies): HttpToken | undefined => {\r\n if (cookies.get) {\r\n const userjson = cookies.get(COOKIE_NAMES.IBOOT_USER);\r\n if (userjson && userjson.length > 0) {\r\n const user = JSON.parse(userjson);\r\n const username = user.username;\r\n const utype = user.userType.toString();\r\n const token = cookies.get(COOKIE_NAMES.IBOOT_TOKEN);\r\n if (token) {\r\n return {\r\n \"username\": username,\r\n \"utype\": utype,\r\n \"token\": token\r\n }\r\n }\r\n }\r\n }\r\n return undefined\r\n}\r\n\r\nexport const setToken = (data: User & { token: string }, cookies: ICookies): void => {\r\n const { id, name, username, nickname, headImg, token, lastLoginTime, deviceId, userType, mustChangePwd } = data;\r\n const loginUser: User = {\r\n id: id,\r\n name: name,\r\n username: username,\r\n nickname: nickname || name,\r\n headImg: headImg,\r\n lastLoginTime: lastLoginTime,\r\n deviceId: deviceId,\r\n userType: userType,\r\n accountType: 0,\r\n needToReview: false,\r\n socketOnline: false,\r\n mustChangePwd: mustChangePwd\r\n };\r\n if (!cookies.set) {\r\n throw new Error('cookies set function is undefined')\r\n }\r\n cookies.set(COOKIE_NAMES.IBOOT_TOKEN, token, {\r\n path: '/',\r\n secure: process.env.APP_ENV === 'production',\r\n httpOnly: true,\r\n sameSite: 'strict'\r\n });\r\n cookies.set(COOKIE_NAMES.IBOOT_USER, JSON.stringify(loginUser))\r\n}\r\n\r\nexport const cleanToken = (cookies: ICookies): void => {\r\n if (!cookies.set) {\r\n throw new Error('cookies set function is undefined')\r\n }\r\n cookies.set(COOKIE_NAMES.IBOOT_TOKEN, '', {\r\n maxAge: -1, //设置为 -1表示立即过期\r\n httpOnly: true,\r\n path: '/',\r\n });\r\n cookies.set(COOKIE_NAMES.IBOOT_USER, '', {\r\n maxAge: -1, //设置为 -1表示立即过期\r\n httpOnly: true,\r\n path: '/',\r\n });\r\n if (!cookies.delete) {\r\n throw new Error('cookies delete function is undefined')\r\n }\r\n cookies.delete(COOKIE_NAMES.IBOOT_TOKEN);\r\n cookies.delete(COOKIE_NAMES.IBOOT_USER);\r\n}\r\n\r\nexport class HttpClient {\r\n private readonly baseUrl: string;\r\n private readonly helloMethod: string;\r\n private readonly apiKey: string;\r\n private readonly userType: USER_TYPE;\r\n private readonly userFrom: string;\r\n private readonly deviceId: string;\r\n private readonly version: string = '1';\r\n private readonly lang: string;\r\n private readonly websiteId?: string;\r\n private readonly websiteNo?: string;\r\n constructor(opts: Readonly<HttpClientOpts>) {\r\n const isProduction = process.env.APP_ENV === 'production';\r\n if (!isProduction) {\r\n logger.warn(\"This is currently a development environment!\")\r\n }\r\n this.baseUrl = process.env.APP_BASEURL!;\r\n this.apiKey = process.env.APP_APIKEY!;\r\n this.userFrom = process.env.APP_USERFROM ?? '1';\r\n\r\n this.helloMethod = opts.helloURL ?? ''\r\n this.userType = opts.userType ?? USER_TYPE_MAP.TYPE_MGT;\r\n this.deviceId = opts.deviceId ?? randomString(10);\r\n this.lang = opts.lang ?? DEFAULT_LOCALE;\r\n this.websiteId = opts.websiteId\r\n this.websiteNo = opts.websiteNo\r\n }\r\n\r\n encrypt(data: string) {\r\n const key = CryptoJS.enc.Utf8.parse(this.apiKey);\r\n return CryptoJS.AES.encrypt(data, key).toString();\r\n }\r\n\r\n decrypt(data: string) {\r\n const key = CryptoJS.enc.Utf8.parse(this.apiKey);\r\n return CryptoJS.AES.decrypt(data, key, {\r\n mode: CryptoJS.mode.ECB,\r\n }).toString(CryptoJS.enc.Utf8);\r\n }\r\n\r\n //eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n private convertUrlParameter(data: Record<string, any>): string {\r\n const p: string[] = [];\r\n for (const o in data) {\r\n let v = data[o];\r\n if (v && typeof v === \"string\") {\r\n v = v.trim();\r\n } else if (v && typeof v === \"object\") {\r\n if (isArray(v)) {\r\n if (v.length === 0) {\r\n continue;\r\n }\r\n for (let i = 0; i < v.length; i++) {\r\n const arr_item = v[i];\r\n for (const item_field in arr_item) {\r\n const item_field_value = arr_item[item_field] ?? undefined;\r\n if (item_field_value) {\r\n if (typeof item_field_value === \"object\") {\r\n if (isArray(item_field_value)) {\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n item_field_value.forEach((item1: any, index: number) => {\r\n if (item1) {\r\n for (const f in item1) {\r\n const v = item1[f];\r\n if (v && v.toString().length > 0) {\r\n const s = `[${i.toString()}].${item_field + `[${index.toString()}].${f}`}=${urlEncode(v)}`;\r\n p.push(o + s);\r\n }\r\n }\r\n }\r\n });\r\n }\r\n } else if (item_field_value.toString().length > 0) {\r\n const s = `[${i.toString()}].${item_field}=${urlEncode(item_field_value.toString())}`;\r\n p.push(o + s);\r\n }\r\n }\r\n }\r\n }\r\n } else {\r\n for (const obj in v) {\r\n const oValue = v[obj];\r\n if (oValue != null && oValue != \"\" && oValue.length != 0) {\r\n const s = `.${obj}=${urlEncode(oValue)}`;\r\n p.push(o + s);\r\n }\r\n }\r\n }\r\n continue;\r\n } else if (v && typeof v === \"function\") {\r\n v = null;\r\n }\r\n\r\n if (v != null && v != \"\" && v.length != 0) {\r\n p.push(o + \"=\" + urlEncode(v));\r\n }\r\n }\r\n return (p && p.join(\"&\"));\r\n }\r\n\r\n private async sign(data: Record<string, object | string>): Promise<string> {\r\n //由后台分配\r\n const _apiKey = \"&key=\" + (await this.helloIboot());\r\n const arr: string[] = [];\r\n for (const o in data) {\r\n arr.push(o);\r\n }\r\n arr.sort((a: string, b: string) => {\r\n return a.toLowerCase().localeCompare(b.toLowerCase());\r\n });\r\n const res: string[] = [];\r\n arr.forEach((v: string) => {\r\n let value: object | string = data[v];\r\n if (typeof value === \"object\") {\r\n value = JSON.stringify(value);\r\n }\r\n res.push(v + \"=\" + value);\r\n });\r\n const paramsStr: string = res.join(\"&\");\r\n const str = md5.md5((paramsStr + _apiKey).toLocaleUpperCase());\r\n const logInfo = {\r\n params: paramsStr,\r\n md5: str\r\n }\r\n logger.debug(logInfo, \"API_SIGN\")\r\n return str;\r\n }\r\n\r\n //eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n private assemblyParameter(data?: Record<string, any>, username?: string): Record<string, any> {\r\n const params = data ?? {};\r\n params['timestamp'] = Date.now() + '';\r\n params['echostr'] = randomString(10);\r\n params['version'] = this.version;\r\n params['deviceId'] = this.deviceId;\r\n params['webid'] = this.websiteId;\r\n params['apiKey'] = this.apiKey;\r\n if (username && username.length > 0) {\r\n params['username'] = username;\r\n }\r\n return params;\r\n }\r\n\r\n private async assemblyHeader({ urlParams, token }: Readonly<{ urlParams: string, token?: Readonly<HttpToken> }>) {\r\n const h: Record<string, string> = {\r\n 'Content-Type': 'application/x-www-form-urlencoded',\r\n 'Res-Type': 'json',\r\n 'Device-Id': this.deviceId,\r\n 'User-Type': token?.utype.toString() ?? this.userType.toString(),\r\n 'User-From': this.userFrom,\r\n 'Api-Key': this.apiKey\r\n }\r\n if (this.lang && this.lang.length > 0) {\r\n h['Lang'] = this.lang\r\n }\r\n if (this.websiteId && this.websiteId.length > 0) {\r\n h['Web-Id'] = this.websiteId\r\n }\r\n if (this.websiteNo && this.websiteNo.length > 0) {\r\n h['Web-No'] = this.websiteNo\r\n }\r\n if (token) {\r\n if (token.token && token.token.length > 0 && token.username && token.username.length > 0) {\r\n h['Authorization'] = token.token;\r\n h['Username'] = token.username;\r\n }\r\n if (token.xcsrf) {\r\n h[token.xcsrf.csrfHeader] = token.xcsrf.csrfToken;\r\n }\r\n }\r\n const data = urlParamToJson(urlParams);\r\n const sign = await this.sign(data);\r\n h['Sign'] = sign\r\n return h;\r\n }\r\n\r\n private async helloIboot(): Promise<string> {\r\n if (this.helloMethod.length <= 0) {\r\n return this.apiKey;\r\n }\r\n const api = this.getApiUrl(this.helloMethod);\r\n const h = {\r\n 'Content-Type': 'application/x-www-form-urlencoded',\r\n 'Res-Type': 'json',\r\n 'Api-Key': this.apiKey\r\n }\r\n const logInfo = {\r\n \"url\": api,\r\n \"headers\": h\r\n }\r\n logger.debug(logInfo, \"HELLO\");\r\n const res = await fetch(api, {\r\n method: 'GET',\r\n headers: h,\r\n credentials: 'include',\r\n cache: 'force-cache'\r\n });\r\n if (res.ok) {\r\n const result = await res.json();\r\n logger.debug(result.data, 'HELLO RESULT')\r\n return result.data;\r\n }\r\n throw new Error('hello iBoot error!')\r\n }\r\n\r\n private getApiUrl(url: string): string {\r\n return `${this.baseUrl}/${url}`;\r\n }\r\n\r\n async csrf(): Promise<string | undefined> {\r\n const res = await this.get<CSRFToken>({\r\n url: 'guest/csrf'\r\n });\r\n if (res.success) {\r\n const data = res.data;\r\n if (data) {\r\n return data[\"csrfToken\"].toString();\r\n }\r\n }\r\n return undefined;\r\n }\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n async get<T>({ url, data, token, cache = 'default' }: Readonly<ServerRequestOptions>): Promise<ResultModel<T>> {\r\n const params = this.assemblyParameter(data);\r\n const urlParams = this.convertUrlParameter(params);\r\n const headers = await this.assemblyHeader({ \"urlParams\": urlParams, \"token\": token });\r\n const api = `${this.getApiUrl(url)}?${urlParams.toString()}`\r\n const logInfo = {\r\n \"url\": api,\r\n \"headers\": headers\r\n }\r\n logger.info(logInfo, \"GET\");\r\n const res = await fetch(api, {\r\n \"method\": 'GET',\r\n \"headers\": headers,\r\n \"credentials\": 'include',\r\n \"cache\": cache\r\n });\r\n if (res.ok) {\r\n const headersMap = Object.fromEntries(res.headers.entries());\r\n const result = { ...await res.json(), headers: headersMap };\r\n logger.debug(result, \"GET_RESULT\")\r\n return result;\r\n }\r\n const msg = {\r\n code: res.status,\r\n success: false,\r\n msg: res.statusText\r\n }\r\n logger.error(msg);\r\n return msg;\r\n }\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n async post<T>({ url, data, token, cache = \"default\" }: Readonly<ServerRequestOptions>): Promise<ResultModel<T>> {\r\n data = data ? { ...data } : {}\r\n const buffer = data.buffer ?? undefined;\r\n const boundary = data.boundary ?? undefined;\r\n if (buffer) {\r\n delete data.buffer;\r\n }\r\n if (boundary) {\r\n delete data.boundary;\r\n }\r\n const params = this.assemblyParameter(data);\r\n const urlParams = this.convertUrlParameter(params);\r\n const headers = await this.assemblyHeader({ \"urlParams\": urlParams, \"token\": token });\r\n if (buffer && boundary) {\r\n headers['Content-Type'] = `multipart/form-data; boundary=${boundary}`;\r\n }\r\n const api = this.getApiUrl(url);\r\n const logInfo = {\r\n \"url\": api,\r\n \"headers\": headers,\r\n \"params\": params\r\n }\r\n logger.info(logInfo, \"POST\");\r\n const urls = buffer ? `${api}?${urlParams}` : api;\r\n const res = await fetch(urls, {\r\n \"method\": 'POST',\r\n \"headers\": headers,\r\n \"body\": buffer ? buffer : urlParams.toString(),\r\n \"credentials\": 'include',\r\n \"cache\": cache\r\n });\r\n if (res.ok) {\r\n const headersMap = Object.fromEntries(res.headers.entries());\r\n const result = { ...await res.json(), headers: headersMap };\r\n logger.debug(result, \"POST_RESULT\");\r\n return result;\r\n }\r\n const msg = {\r\n code: res.status,\r\n success: false,\r\n msg: res.statusText\r\n }\r\n logger.error(msg);\r\n return msg;\r\n }\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n async stream({ url, data, token }: Readonly<Omit<ServerRequestOptions, 'cache'>>): Promise<Response> {\r\n data = data ? { ...data } : {}\r\n const buffer = data.buffer ?? undefined;\r\n const boundary = data.boundary ?? undefined;\r\n if (buffer) {\r\n delete data.buffer;\r\n }\r\n if (boundary) {\r\n delete data.boundary;\r\n }\r\n const params = this.assemblyParameter(data);\r\n const urlParams = this.convertUrlParameter(params); //new URLSearchParams(params);\r\n\r\n const headers = await this.assemblyHeader({ \"urlParams\": urlParams, \"token\": token });\r\n if (buffer && boundary) {\r\n headers['Content-Type'] = `multipart/form-data; boundary=${boundary}`;\r\n }\r\n headers['Connection'] = 'keep-alive';\r\n headers['X-Accel-Buffering'] = 'no'; //防止 Nginx 缓存\r\n headers['Cache-Control'] = 'no-cache';\r\n const api = this.getApiUrl(url)\r\n try {\r\n const url = buffer ? `${api}?${urlParams}` : api;\r\n const logInfo = {\r\n \"url\": api,\r\n \"headers\": headers,\r\n \"params\": params\r\n }\r\n logger.info(logInfo, \"STREAM\");\r\n const res = await fetch(url, {\r\n method: 'POST',\r\n headers: headers,\r\n body: buffer ? buffer : urlParams.toString(),\r\n credentials: 'include'\r\n });\r\n\r\n if (!res.ok) {\r\n throw new Error(`HTTP error! status: ${res.status}`);\r\n }\r\n if (!res.body) {\r\n throw new Error('No response body');\r\n }\r\n const headersMap = Object.fromEntries(res.headers.entries());\r\n return new Response(res.body, {\r\n headers: headersMap\r\n });\r\n } catch (e) {\r\n throw e;\r\n }\r\n }\r\n}"],"names":["ACCOUNT_TYPE_MAP","USER_TYPE_MAP","USER_FORM_MAP","USER_SEX_MAP","stream","PinoPretty","logger","pino","isArray","obj","randomString","len","l","$chars","maxPos","pwd","i","urlParamToJson","urlQueryParams","exclude","result","item","arr","urlEncode","value","dateFormat","dt","fmt","o","k","regx","DEFAULT_LOCALE","DEVICE_ID_KEY","CURRENT_WEBSITE_KEY","_GET_ERROR","_POST_ERROR","COOKIE_NAMES","HEADER_NAMES","getDefaultRequestHeader","storage","devideId","json","curWebsite","header","setDefaultRequestHeader","deviceId","website","get","url","opts","params","headers","heads","field","res","headersMap","msg","post","data","body","defaultHeads","proxyHeaders","iGet","iPost","iPostSuccess","getHttpOpts","lang","websiteId","websiteNo","getLoginUser","cookies","userjson","getToken","user","username","utype","token","setToken","id","name","nickname","headImg","lastLoginTime","userType","mustChangePwd","loginUser","cleanToken","HttpClient","key","CryptoJS","p","v","arr_item","item_field","item_field_value","item1","index","f","s","oValue","_apiKey","a","b","paramsStr","str","md5","logInfo","urlParams","h","sign","api","cache","buffer","boundary","urls","e"],"mappings":"4KAAaA,EAAmB,CAC5B,QAAU,EACV,MAAQ,EACR,MAAQ,CACZ,EAEaC,EAAgB,CACzB,SAAW,EACX,OAAS,EACT,OAAS,CACb,EAEaC,EAAgB,CACzB,SAAW,EACX,QAAU,EACV,iBAAmB,EACnB,YAAc,EACd,UAAY,EACZ,SAAW,EACX,YAAc,CAClB,EAEaC,EAAe,CACxB,QAAQ,EACR,KAAK,EACL,OAAO,CACX,ECOMC,EAASC,EAAW,CACtB,SAAU,GACV,YAAa,QAAQ,OACrB,cAAe,0BACf,OAAQ,eACR,cAAe,QACf,WAAY,EAChB,CAAC,EAEYC,EAASC,EAAK,CACvB,KAAM,QAAQ,IAAI,UAAY,QAC9B,MAAO,QAAQ,IAAI,UAAY,aAAe,OAAS,QACvD,UAAW,SACf,EAAGH,CAAM,EC9CII,EAAWC,GAEpB,MAAM,QAAQA,CAAG,GAChB,OAAOA,GAAQ,UACd,OAAO,UAAU,SAAS,KAAKA,CAAG,IAAM,iBAQjCC,EAAgBC,GAAgB,CAC3C,MAAMC,EAAID,GAAO,GACXE,EAAS,mDACTC,EAASD,EAAO,OACtB,IAAIE,EAAM,GACV,QAASC,EAAI,EAAGA,EAAIJ,EAAGI,IACrBD,GAAOF,EAAO,OAAO,KAAK,MAAM,KAAK,SAAWC,CAAM,CAAC,EAEzD,OAAOC,CACT,EAEaE,EAAiB,CAACC,EAAwBC,IAA+C,CACpG,MAAMC,EAAiC,CAAA,EAEvC,OADaF,EAAe,MAAM,GAAG,EAChC,QAASG,GAAS,CACrB,MAAMC,EAAMD,EAAK,MAAM,GAAG,EACtBC,EAAI,CAAC,IACH,CAACH,GAAWA,EAAQ,QAAQG,EAAI,CAAC,CAAC,GAAK,MACzCF,EAAOE,EAAI,CAAC,CAAC,EAAIA,EAAI,CAAC,EAG5B,CAAC,EACMF,CACT,EAEaG,EAAaC,GACpB,CAACA,GAASA,GAAS,IAAMA,EAAM,QAAU,EACpC,GAGP,mBAAmBA,CAAK,EAGrB,QAAQ,MAAO,KAAK,EACpB,QAAQ,MAAO,KAAK,EACpB,QAAQ,MAAO,KAAK,EACpB,QAAQ,MAAO,KAAK,EACpB,QAAQ,MAAO,KAAK,EAIdC,EAAa,CAACC,EAAUC,IAAgB,CACjD,MAAMC,EAA2B,CAC7B,KAAMF,EAAG,SAAA,EAAa,EACtB,KAAMA,EAAG,QAAA,EACT,KAAMA,EAAG,SAAA,EACT,KAAMA,EAAG,WAAA,EACT,KAAMA,EAAG,WAAA,EACT,KAAM,KAAK,OAAOA,EAAG,SAAA,EAAa,GAAK,CAAC,EACxC,EAAGA,EAAG,gBAAA,CAAgB,EAE1B,GAAI,OAAO,KAAKC,CAAG,EAAE,CAEjB,MAAMH,EADO,IAAI,OAAO,MAAM,EACX,KAAKG,CAAG,EAC3B,IAAIhB,EAAM,EACPa,GAASA,EAAM,OAAS,IACvBb,EAAMa,EAAM,CAAC,EAAE,QAEnBG,EAAMA,EAAI,QAAQ,OAAQD,EAAG,YAAA,EAAgB,EAAE,EAAE,UAAU,EAAIf,CAAG,CACtE,CAEA,UAAWkB,KAAKD,EAAE,CACd,MAAM,EAAW,IAAMC,EAAI,IACrBC,EAAO,IAAI,OAAO,CAAC,EACzB,GAAGA,EAAK,KAAKH,CAAG,EAAE,CACd,MAAMH,EAAQM,EAAK,KAAKH,CAAG,EAC3B,IAAIhB,EAAM,EACPa,GAASA,EAAM,OAAS,IACvBb,EAAMa,EAAM,CAAC,EAAE,QAEnBG,EAAMA,EAAI,QAAQG,EAAMnB,GAAO,EAAIiB,EAAEC,CAAC,EAAE,SAAA,GAAc,KAAOD,EAAEC,CAAC,GAAG,UAAUD,EAAEC,CAAC,EAAE,WAAW,MAAM,CAAC,CACxG,CACJ,CACA,OAAOF,CACX,EClEaI,EAAiB,QACjBC,EAAgB,iBAChBC,EAAsB,uBAE7BC,EAAa,qBACbC,EAAc,sBAEPC,EAAe,CACxB,gBAAmB,OACnB,WAAc,OACd,iBAAoB,MACpB,iBAAoB,MACpB,YAAe,QACf,WAAc,MAClB,EAEaC,EAAe,CACxB,UAAa,YACb,KAAQ,OACR,WAAc,aACd,WAAc,YAClB,EAGMC,EAA2BC,GAA6C,CAC1E,GAAI,CAACA,EAAQ,IACT,MAAM,IAAI,MAAM,sDAAsD,EAE1E,MAAMC,EAAWD,EAAQ,IAAIP,CAAa,GAAK,GACzCS,EAAOF,EAAQ,IAAIN,CAAmB,EACtCS,EAAgCD,GAAQ,KAAO,KAAK,MAAMA,CAAI,EAAI,KAClEE,EAAsB,CAAA,EAC5B,OAAIH,EAAS,OAAS,IAClBG,EAAO,WAAW,EAAIH,GAEtBE,IACAC,EAAO,KAAUD,EAAW,SACxBA,EAAW,YACXC,EAAO,YAAY,EAAID,EAAW,WAElCA,EAAW,YACXC,EAAO,YAAY,EAAID,EAAW,YAGnCC,CACX,EAGaC,EAA0B,CAAC,CAAE,SAAAC,EAAU,QAAAC,CAAA,EAAiEP,IAA4B,CAC7I,GAAI,CAACA,EAAQ,IACT,MAAM,IAAI,MAAM,sDAAsD,EAE1EA,EAAQ,IAAIP,EAAea,CAAQ,EAC/BC,GACAP,EAAQ,IAAIN,EAAqB,KAAK,UAAUa,CAAO,CAAC,CAEhE,EAEaC,EAAM,MAAUC,EAAaC,IAAoD,CAC1F,GAAIA,GAAM,KAAM,CACZ,MAAMC,EAAS,IAAI,gBAAgBD,EAAK,IAAI,EACxCD,EAAI,QAAQ,GAAG,GAAK,GACpBA,GAAO,IAAIE,CAAM,GAEjBF,GAAO,IAAIE,CAAM,EAEzB,CACA,MAAMC,EAAmCF,GAAQA,EAAK,SAAWA,EAAK,QAAQ,IAAOX,EAAwBW,EAAK,OAAO,EAAI,CAAA,EACvHG,EAAQH,GAAM,QACpB,GAAIG,EACA,UAAWC,KAASD,EAAO,CACvB,MAAM5B,EAAQ4B,EAAMC,CAAK,EACrB7B,IACA2B,EAAQE,CAAK,EAAI7B,EAEzB,CAEJlB,EAAO,KAAK,CACR,IAAO0C,EACP,QAAWG,CAAA,EACZ,KAAK,EACR,MAAMG,EAAM,MAAM,MAAMN,EAAK,CACzB,OAAQ,MACR,QAAAG,EACA,MAAOF,GAAM,SAAW,cAAgB,SAAA,CAC3C,EAED,GAAIK,EAAI,GAAI,CACR,MAAMC,EAAa,OAAO,YAAYD,EAAI,QAAQ,SAAS,EACrDlC,EAAS,CAAE,GAAG,MAAMkC,EAAI,KAAA,EAAQ,QAASC,CAAA,EAC/C,OAAAjD,EAAO,MAAMc,EAAQ,YAAY,EAC1BA,CACX,CACA,MAAMoC,EAAM,CACR,KAAMF,EAAI,OACV,QAAS,GACT,IAAKA,EAAI,UAAA,EAEb,OAAAhD,EAAO,MAAMkD,CAAG,EACTA,CACX,EAEaC,EAAO,MAAUT,EAAaC,IAAqD,CAC5F,MAAMS,EAAOT,GAAM,MAAQ,CAAA,EACrBG,EAAQH,GAAM,QACpB,IAAIU,EACJ,MAAMC,EAAgBX,GAAQA,EAAK,SAAWA,EAAK,QAAQ,IAAOX,EAAwBW,EAAK,OAAO,EAAI,CAAA,EACpGY,EAAe,IAAI,QAAQD,CAAY,EAO7C,GANMF,aAAgB,SAIlBC,EAAOD,GAHPC,EAAO,KAAK,UAAUD,CAAI,EAC1BG,EAAa,IAAI,eAAgB,kBAAkB,GAInDT,EACA,QAASC,KAASD,EAAO,CACrB,MAAM5B,EAAQ4B,EAAMC,CAAK,EACrB7B,GACAqC,EAAa,IAAIR,EAAO7B,CAAK,CAErC,CAEJlB,EAAO,KAAK,CACR,IAAO0C,EACP,QAAWa,CAAA,EACZ,MAAM,EACT,MAAMP,EAAM,MAAM,MAAMN,EAAK,CACzB,OAAQ,OACR,QAASa,EACT,KAAAF,CAAA,CACH,EACD,GAAIL,EAAI,GAAI,CACR,MAAMC,EAAa,OAAO,YAAYD,EAAI,QAAQ,SAAS,EACrDlC,EAAS,CAAE,GAAG,MAAMkC,EAAI,KAAA,EAAQ,QAASC,CAAA,EAC/C,OAAAjD,EAAO,MAAMc,EAAQ,aAAa,EAC3BA,CACX,CACA,MAAMoC,EAAM,CACR,KAAMF,EAAI,OACV,QAAS,GACT,IAAKA,EAAI,UAAA,EAEb,OAAAhD,EAAO,MAAMkD,CAAG,EACTA,CACX,EAEaM,EAAO,MAAUd,EAAaC,IAAmD,CAC1F,MAAMK,EAAM,MAAMP,EAAOC,EAAKC,CAAI,EAClC,GAAIK,EAAI,QACJ,OAAOA,EAAI,KAEf,GAAIL,GAAM,UAAW,CACjBA,EAAK,UAAUK,EAAI,KAAOpB,CAAU,EACpC,MACJ,CACA,MAAM,MAAMoB,EAAI,KAAOpB,CAAU,CACrC,EAEa6B,EAAQ,MAAUf,EAAaC,IAAoD,CAC5F,MAAMK,EAAM,MAAMG,EAAQT,EAAKC,CAAI,EACnC,GAAIK,EAAI,QACJ,OAAOA,EAAI,KAEf,GAAIL,GAAM,UAAW,CACjBA,EAAK,UAAUK,EAAI,KAAOnB,CAAW,EACrC,MACJ,CACA,MAAM,MAAMmB,EAAI,KAAOnB,CAAW,CACtC,EAEa6B,EAAe,MAAOhB,EAAaC,IAA8C,CAC1F,MAAMK,EAAM,MAAMG,EAAKT,EAAKC,CAAI,EAChC,OAAIK,EAAI,SACAL,GAAM,aACNA,EAAK,YAAYK,EAAI,KAAO,SAAS,EAElC,KAEPL,GAAM,WACNA,EAAK,UAAUK,EAAI,KAAOnB,CAAW,EAElC,GACX,EAEa8B,EAAe1B,GAAsC,CAC9D,GAAIA,EAAQ,IAAK,CACb,MAAMM,EAAWN,EAAQ,IAAIF,EAAa,SAAS,EAC7C6B,EAAO3B,EAAQ,IAAIF,EAAa,IAAI,EACpC8B,EAAY5B,EAAQ,IAAIF,EAAa,UAAU,EAC/C+B,EAAY7B,EAAQ,IAAIF,EAAa,UAAU,EAC/CjB,EAAyB,CAAA,EAC/B,OAAIyB,GAAYA,EAAS,OAAS,IAC9BzB,EAAO,SAAWyB,GAElBqB,GAAQA,EAAK,OAAS,IACtB9C,EAAO,KAAO8C,GAEdC,GAAaA,EAAU,OAAS,IAChC/C,EAAO,UAAY+C,GAEnBC,GAAaA,EAAU,OAAS,IAChChD,EAAO,UAAYgD,GAEhBhD,CACX,CACC,MAAM,IAAI,MAAM,sDAAsD,CAC3E,EAEaiD,EAAgBC,GAAwC,CACjE,GAAIA,EAAQ,IAAK,CACb,MAAMC,EAAWD,EAAQ,IAAIlC,EAAa,UAAU,EACpD,GAAImC,GAAYA,EAAS,OAAS,EAC9B,OAAO,KAAK,MAAMA,CAAQ,CAElC,CAEJ,EAEaC,EAAYF,GAA6C,CAClE,GAAIA,EAAQ,IAAK,CACb,MAAMC,EAAWD,EAAQ,IAAIlC,EAAa,UAAU,EACpD,GAAImC,GAAYA,EAAS,OAAS,EAAG,CACjC,MAAME,EAAO,KAAK,MAAMF,CAAQ,EAC1BG,EAAWD,EAAK,SAChBE,EAAQF,EAAK,SAAS,SAAA,EACtBG,EAAQN,EAAQ,IAAIlC,EAAa,WAAW,EAClD,GAAIwC,EACA,MAAO,CACH,SAAYF,EACZ,MAASC,EACT,MAASC,CAAA,CAGrB,CACJ,CAEJ,EAEaC,EAAW,CAACnB,EAAgCY,IAA4B,CACjF,KAAM,CAAE,GAAAQ,EAAI,KAAAC,EAAM,SAAAL,EAAU,SAAAM,EAAU,QAAAC,EAAS,MAAAL,EAAO,cAAAM,EAAe,SAAArC,EAAU,SAAAsC,EAAU,cAAAC,CAAA,EAAkB1B,EACrG2B,EAAkB,CACpB,GAAAP,EACA,KAAAC,EACA,SAAAL,EACA,SAAUM,GAAYD,EACtB,QAAAE,EACA,cAAAC,EACA,SAAArC,EACA,SAAAsC,EACA,YAAa,EACb,aAAc,GACd,aAAc,GACd,cAAAC,CAAA,EAEJ,GAAI,CAACd,EAAQ,IACT,MAAM,IAAI,MAAM,mCAAmC,EAEvDA,EAAQ,IAAIlC,EAAa,YAAawC,EAAO,CACzC,KAAM,IACN,OAAQ,QAAQ,IAAI,UAAY,aAChC,SAAU,GACV,SAAU,QAAA,CACb,EACDN,EAAQ,IAAIlC,EAAa,WAAY,KAAK,UAAUiD,CAAS,CAAC,CAClE,EAEaC,EAAchB,GAA4B,CACnD,GAAI,CAACA,EAAQ,IACT,MAAM,IAAI,MAAM,mCAAmC,EAYvD,GAVAA,EAAQ,IAAIlC,EAAa,YAAa,GAAI,CACtC,OAAQ,GACR,SAAU,GACV,KAAM,GAAA,CACT,EACDkC,EAAQ,IAAIlC,EAAa,WAAY,GAAI,CACrC,OAAQ,GACR,SAAU,GACV,KAAM,GAAA,CACT,EACG,CAACkC,EAAQ,OACT,MAAM,IAAI,MAAM,sCAAsC,EAE1DA,EAAQ,OAAOlC,EAAa,WAAW,EACvCkC,EAAQ,OAAOlC,EAAa,UAAU,CAC1C,EAEO,MAAMmD,CAAW,CACH,QACA,YACA,OACA,SACA,SACA,SACA,QAAkB,IAClB,KACA,UACA,UACjB,YAAYtC,EAAgC,CACnB,QAAQ,IAAI,UAAY,cAEzC3C,EAAO,KAAK,8CAA8C,EAE9D,KAAK,QAAU,QAAQ,IAAI,YAC3B,KAAK,OAAS,QAAQ,IAAI,WAC1B,KAAK,SAAW,QAAQ,IAAI,cAAgB,IAE5C,KAAK,YAAc2C,EAAK,UAAY,GACpC,KAAK,SAAWA,EAAK,UAAYhD,EAAc,SAC/C,KAAK,SAAWgD,EAAK,UAAYvC,EAAa,EAAE,EAChD,KAAK,KAAOuC,EAAK,MAAQlB,EACzB,KAAK,UAAYkB,EAAK,UACtB,KAAK,UAAYA,EAAK,SAC1B,CAEA,QAAQS,EAAc,CAClB,MAAM8B,EAAMC,EAAS,IAAI,KAAK,MAAM,KAAK,MAAM,EAC/C,OAAOA,EAAS,IAAI,QAAQ/B,EAAM8B,CAAG,EAAE,SAAA,CAC3C,CAEA,QAAQ9B,EAAc,CAClB,MAAM8B,EAAMC,EAAS,IAAI,KAAK,MAAM,KAAK,MAAM,EAC/C,OAAOA,EAAS,IAAI,QAAQ/B,EAAM8B,EAAK,CACnC,KAAMC,EAAS,KAAK,GAAA,CACvB,EAAE,SAASA,EAAS,IAAI,IAAI,CACjC,CAGQ,oBAAoB/B,EAAmC,CAC3D,MAAMgC,EAAc,CAAA,EACpB,UAAW9D,KAAK8B,EAAM,CAClB,IAAIiC,EAAIjC,EAAK9B,CAAC,EACd,GAAI+D,GAAK,OAAOA,GAAM,SAClBA,EAAIA,EAAE,KAAA,UACCA,GAAK,OAAOA,GAAM,SAAU,CACnC,GAAInF,EAAQmF,CAAC,EAAG,CACZ,GAAIA,EAAE,SAAW,EACb,SAEJ,QAAS3E,EAAI,EAAGA,EAAI2E,EAAE,OAAQ3E,IAAK,CAC/B,MAAM4E,EAAWD,EAAE3E,CAAC,EACpB,UAAW6E,KAAcD,EAAU,CAC/B,MAAME,EAAmBF,EAASC,CAAU,GAAK,OACjD,GAAIC,GACA,GAAI,OAAOA,GAAqB,SACxBtF,EAAQsF,CAAgB,GAExBA,EAAiB,QAAQ,CAACC,EAAYC,IAAkB,CACpD,GAAID,EACA,UAAWE,KAAKF,EAAO,CACnB,MAAMJ,EAAII,EAAME,CAAC,EACjB,GAAIN,GAAKA,EAAE,SAAA,EAAW,OAAS,EAAG,CAC9B,MAAMO,EAAI,IAAIlF,EAAE,SAAA,CAAU,KAAK6E,EAAa,IAAIG,EAAM,SAAA,CAAU,KAAKC,CAAC,EAAE,IAAI1E,EAAUoE,CAAC,CAAC,GACxFD,EAAE,KAAK9D,EAAIsE,CAAC,CAChB,CACJ,CAER,CAAC,UAEEJ,EAAiB,SAAA,EAAW,OAAS,EAAG,CAC/C,MAAMI,EAAI,IAAIlF,EAAE,SAAA,CAAU,KAAK6E,CAAU,IAAItE,EAAUuE,EAAiB,SAAA,CAAU,CAAC,GACnFJ,EAAE,KAAK9D,EAAIsE,CAAC,CAChB,EAER,CACJ,CACJ,KACI,WAAWzF,KAAOkF,EAAG,CACjB,MAAMQ,EAASR,EAAElF,CAAG,EACpB,GAAI0F,GAAU,MAAQA,GAAU,IAAMA,EAAO,QAAU,EAAG,CACtD,MAAMD,EAAI,IAAIzF,CAAG,IAAIc,EAAU4E,CAAM,CAAC,GACtCT,EAAE,KAAK9D,EAAIsE,CAAC,CAChB,CACJ,CAEJ,QACJ,MAAWP,GAAK,OAAOA,GAAM,aACzBA,EAAI,MAGJA,GAAK,MAAQA,GAAK,IAAMA,EAAE,QAAU,GACpCD,EAAE,KAAK9D,EAAI,IAAML,EAAUoE,CAAC,CAAC,CAErC,CACA,OAAQD,GAAKA,EAAE,KAAK,GAAG,CAC3B,CAEA,MAAc,KAAKhC,EAAwD,CAEvE,MAAM0C,EAAU,QAAW,MAAM,KAAK,WAAA,EAChC9E,EAAgB,CAAA,EACtB,UAAWM,KAAK8B,EACZpC,EAAI,KAAKM,CAAC,EAEdN,EAAI,KAAK,CAAC+E,EAAWC,IACVD,EAAE,YAAA,EAAc,cAAcC,EAAE,aAAa,CACvD,EACD,MAAMhD,EAAgB,CAAA,EACtBhC,EAAI,QAASqE,GAAc,CACvB,IAAInE,EAAyBkC,EAAKiC,CAAC,EAC/B,OAAOnE,GAAU,WACjBA,EAAQ,KAAK,UAAUA,CAAK,GAEhC8B,EAAI,KAAKqC,EAAI,IAAMnE,CAAK,CAC5B,CAAC,EACD,MAAM+E,EAAoBjD,EAAI,KAAK,GAAG,EAChCkD,EAAMC,EAAI,KAAKF,EAAYH,GAAS,mBAAmB,EACvDM,EAAU,CACZ,OAAQH,EACR,IAAKC,CAAA,EAET,OAAAlG,EAAO,MAAMoG,EAAS,UAAU,EACzBF,CACX,CAGQ,kBAAkB9C,EAA4BgB,EAAwC,CAC1F,MAAMxB,EAASQ,GAAQ,CAAA,EACvB,OAAAR,EAAO,UAAe,KAAK,IAAA,EAAQ,GACnCA,EAAO,QAAaxC,EAAa,EAAE,EACnCwC,EAAO,QAAa,KAAK,QACzBA,EAAO,SAAc,KAAK,SAC1BA,EAAO,MAAW,KAAK,UACvBA,EAAO,OAAY,KAAK,OACpBwB,GAAYA,EAAS,OAAS,IAC9BxB,EAAO,SAAcwB,GAElBxB,CACX,CAEA,MAAc,eAAe,CAAE,UAAAyD,EAAW,MAAA/B,GAAuE,CAC7G,MAAMgC,EAA4B,CAC9B,eAAgB,oCAChB,WAAY,OACZ,YAAa,KAAK,SAClB,YAAahC,GAAO,MAAM,YAAc,KAAK,SAAS,SAAA,EACtD,YAAa,KAAK,SAClB,UAAW,KAAK,MAAA,EAEhB,KAAK,MAAQ,KAAK,KAAK,OAAS,IAChCgC,EAAE,KAAU,KAAK,MAEjB,KAAK,WAAa,KAAK,UAAU,OAAS,IAC1CA,EAAE,QAAQ,EAAI,KAAK,WAEnB,KAAK,WAAa,KAAK,UAAU,OAAS,IAC1CA,EAAE,QAAQ,EAAI,KAAK,WAEnBhC,IACIA,EAAM,OAASA,EAAM,MAAM,OAAS,GAAKA,EAAM,UAAYA,EAAM,SAAS,OAAS,IACnFgC,EAAE,cAAmBhC,EAAM,MAC3BgC,EAAE,SAAchC,EAAM,UAEtBA,EAAM,QACNgC,EAAEhC,EAAM,MAAM,UAAU,EAAIA,EAAM,MAAM,YAGhD,MAAMlB,EAAOzC,EAAe0F,CAAS,EAC/BE,EAAO,MAAM,KAAK,KAAKnD,CAAI,EACjC,OAAAkD,EAAE,KAAUC,EACLD,CACX,CAEA,MAAc,YAA8B,CACxC,GAAI,KAAK,YAAY,QAAU,EAC3B,OAAO,KAAK,OAEhB,MAAME,EAAM,KAAK,UAAU,KAAK,WAAW,EACrCF,EAAI,CACN,eAAgB,oCAChB,WAAY,OACZ,UAAW,KAAK,MAAA,EAEdF,EAAU,CACZ,IAAOI,EACP,QAAWF,CAAA,EAEftG,EAAO,MAAMoG,EAAS,OAAO,EAC7B,MAAMpD,EAAM,MAAM,MAAMwD,EAAK,CACzB,OAAQ,MACR,QAASF,EACT,YAAa,UACb,MAAO,aAAA,CACV,EACD,GAAItD,EAAI,GAAI,CACR,MAAMlC,EAAS,MAAMkC,EAAI,KAAA,EACzB,OAAAhD,EAAO,MAAMc,EAAO,KAAM,cAAc,EACjCA,EAAO,IAClB,CACA,MAAM,IAAI,MAAM,oBAAoB,CACxC,CAEQ,UAAU4B,EAAqB,CACnC,MAAO,GAAG,KAAK,OAAO,IAAIA,CAAG,EACjC,CAEA,MAAM,MAAoC,CACtC,MAAMM,EAAM,MAAM,KAAK,IAAe,CAClC,IAAK,YAAA,CACR,EACD,GAAIA,EAAI,QAAS,CACb,MAAMI,EAAOJ,EAAI,KACjB,GAAII,EACA,OAAOA,EAAK,UAAa,SAAA,CAEjC,CAEJ,CAGA,MAAM,IAAO,CAAE,IAAAV,EAAK,KAAAU,EAAM,MAAAkB,EAAO,MAAAmC,EAAQ,WAAsE,CAC3G,MAAM7D,EAAS,KAAK,kBAAkBQ,CAAI,EACpCiD,EAAY,KAAK,oBAAoBzD,CAAM,EAC3CC,EAAU,MAAM,KAAK,eAAe,CAAE,UAAawD,EAAW,MAAS/B,EAAO,EAC9EkC,EAAM,GAAG,KAAK,UAAU9D,CAAG,CAAC,IAAI2D,EAAU,SAAA,CAAU,GACpDD,EAAU,CACZ,IAAOI,EACP,QAAW3D,CAAA,EAEf7C,EAAO,KAAKoG,EAAS,KAAK,EAC1B,MAAMpD,EAAM,MAAM,MAAMwD,EAAK,CACzB,OAAU,MACV,QAAW3D,EACX,YAAe,UACf,MAAS4D,CAAA,CACZ,EACD,GAAIzD,EAAI,GAAI,CACR,MAAMC,EAAa,OAAO,YAAYD,EAAI,QAAQ,SAAS,EACrDlC,EAAS,CAAE,GAAG,MAAMkC,EAAI,KAAA,EAAQ,QAASC,CAAA,EAC/C,OAAAjD,EAAO,MAAMc,EAAQ,YAAY,EAC1BA,CACX,CACA,MAAMoC,EAAM,CACR,KAAMF,EAAI,OACV,QAAS,GACT,IAAKA,EAAI,UAAA,EAEb,OAAAhD,EAAO,MAAMkD,CAAG,EACTA,CACX,CAGA,MAAM,KAAQ,CAAE,IAAAR,EAAK,KAAAU,EAAM,MAAAkB,EAAO,MAAAmC,EAAQ,WAAsE,CAC5GrD,EAAOA,EAAO,CAAE,GAAGA,CAAA,EAAS,CAAA,EAC5B,MAAMsD,EAAStD,EAAK,QAAU,OACxBuD,EAAWvD,EAAK,UAAY,OAC9BsD,GACA,OAAOtD,EAAK,OAEZuD,GACA,OAAOvD,EAAK,SAEhB,MAAMR,EAAS,KAAK,kBAAkBQ,CAAI,EACpCiD,EAAY,KAAK,oBAAoBzD,CAAM,EAC3CC,EAAU,MAAM,KAAK,eAAe,CAAE,UAAawD,EAAW,MAAS/B,EAAO,EAChFoC,GAAUC,IACV9D,EAAQ,cAAc,EAAI,iCAAiC8D,CAAQ,IAEvE,MAAMH,EAAM,KAAK,UAAU9D,CAAG,EACxB0D,EAAU,CACZ,IAAOI,EACP,QAAW3D,EACX,OAAUD,CAAA,EAEd5C,EAAO,KAAKoG,EAAS,MAAM,EAC3B,MAAMQ,EAAOF,EAAS,GAAGF,CAAG,IAAIH,CAAS,GAAKG,EACxCxD,EAAM,MAAM,MAAM4D,EAAM,CAC1B,OAAU,OACV,QAAW/D,EACX,KAAQ6D,GAAkBL,EAAU,SAAA,EACpC,YAAe,UACf,MAASI,CAAA,CACZ,EACD,GAAIzD,EAAI,GAAI,CACR,MAAMC,EAAa,OAAO,YAAYD,EAAI,QAAQ,SAAS,EACrDlC,EAAS,CAAE,GAAG,MAAMkC,EAAI,KAAA,EAAQ,QAASC,CAAA,EAC/C,OAAAjD,EAAO,MAAMc,EAAQ,aAAa,EAC3BA,CACX,CACA,MAAMoC,EAAM,CACR,KAAMF,EAAI,OACV,QAAS,GACT,IAAKA,EAAI,UAAA,EAEb,OAAAhD,EAAO,MAAMkD,CAAG,EACTA,CACX,CAGA,MAAM,OAAO,CAAE,IAAAR,EAAK,KAAAU,EAAM,MAAAkB,GAA2E,CACjGlB,EAAOA,EAAO,CAAE,GAAGA,CAAA,EAAS,CAAA,EAC5B,MAAMsD,EAAStD,EAAK,QAAU,OACxBuD,EAAWvD,EAAK,UAAY,OAC9BsD,GACA,OAAOtD,EAAK,OAEZuD,GACA,OAAOvD,EAAK,SAEhB,MAAMR,EAAS,KAAK,kBAAkBQ,CAAI,EACpCiD,EAAY,KAAK,oBAAoBzD,CAAM,EAE3CC,EAAU,MAAM,KAAK,eAAe,CAAE,UAAawD,EAAW,MAAS/B,EAAO,EAChFoC,GAAUC,IACV9D,EAAQ,cAAc,EAAI,iCAAiC8D,CAAQ,IAEvE9D,EAAQ,WAAgB,aACxBA,EAAQ,mBAAmB,EAAI,KAC/BA,EAAQ,eAAe,EAAI,WAC3B,MAAM2D,EAAM,KAAK,UAAU9D,CAAG,EAC9B,GAAI,CACA,MAAMA,EAAMgE,EAAS,GAAGF,CAAG,IAAIH,CAAS,GAAKG,EACvCJ,EAAU,CACZ,IAAOI,EACP,QAAW3D,EACX,OAAUD,CAAA,EAEd5C,EAAO,KAAKoG,EAAS,QAAQ,EAC7B,MAAMpD,EAAM,MAAM,MAAMN,EAAK,CACzB,OAAQ,OACR,QAAAG,EACA,KAAM6D,GAAkBL,EAAU,SAAA,EAClC,YAAa,SAAA,CAChB,EAED,GAAI,CAACrD,EAAI,GACL,MAAM,IAAI,MAAM,uBAAuBA,EAAI,MAAM,EAAE,EAEvD,GAAI,CAACA,EAAI,KACL,MAAM,IAAI,MAAM,kBAAkB,EAEtC,MAAMC,EAAa,OAAO,YAAYD,EAAI,QAAQ,SAAS,EAC3D,OAAO,IAAI,SAASA,EAAI,KAAM,CAC1B,QAASC,CAAA,CACZ,CACL,OAAS4D,EAAG,CACR,MAAMA,CACV,CACJ,CACJ"}
@@ -479,6 +479,7 @@ export {
479
479
  P as CURRENT_WEBSITE_KEY,
480
480
  j as DEFAULT_LOCALE,
481
481
  I as DEVICE_ID_KEY,
482
+ y as HEADER_NAMES,
482
483
  te as HttpClient,
483
484
  W as USER_FORM_MAP,
484
485
  G as USER_SEX_MAP,
@@ -1 +1 @@
1
- {"version":3,"file":"iboot-http-client.es.js","sources":["../src/types/user.ts","../src/logger.ts","../src/utils.ts","../src/http-client.ts"],"sourcesContent":["export const ACCOUNT_TYPE_MAP = {\r\n GENERAL : 0,\r\n PHONE : 1,\r\n EMAIL : 2\r\n}\r\n\r\nexport const USER_TYPE_MAP = {\r\n TYPE_MGT : 0,\r\n TYPE_C : 1,\r\n TYPE_B : 2\r\n}\r\n\r\nexport const USER_FORM_MAP = {\r\n FROM_WEB : 1,\r\n FROM_PC : 2,\r\n FROM_WX_MINI_PRO : 3,\r\n FROM_WX_PLU : 4,\r\n FROM_WX_E : 5,\r\n FROM_APP : 6,\r\n FROM_DEVICE : 7\r\n}\r\n\r\nexport const USER_SEX_MAP = {\r\n unknown:0,\r\n male:1,\r\n female:2,\r\n}\r\n\r\nexport type ACCOUNT_TYPE = typeof ACCOUNT_TYPE_MAP[keyof typeof ACCOUNT_TYPE_MAP];\r\nexport type USER_TYPE = typeof USER_TYPE_MAP[keyof typeof USER_TYPE_MAP];\r\nexport type USER_FORM = typeof USER_FORM_MAP[keyof typeof USER_FORM_MAP];\r\nexport type USER_SEX = typeof USER_SEX_MAP[keyof typeof USER_SEX_MAP];\r\n\r\n// User interface\r\nexport interface User {\r\n id: string;\r\n name: string;\r\n userType: USER_TYPE;\r\n username?: string;\r\n nickname?: string;\r\n sex?: USER_SEX;\r\n headImg?: string;\r\n lastLoginTime?: string;\r\n tokenExpired?: string;\r\n deviceId?: string;\r\n status?: number;\r\n accountType?: number;\r\n enabled?: boolean;\r\n userFrom?: USER_FORM;\r\n needToReview?: boolean;\r\n socketOnline?: boolean;\r\n createTime?: string;\r\n mustChangePwd?: boolean;\r\n}","import pino from \"pino\";\r\nimport PinoPretty from \"pino-pretty\";\r\n// import koffi from 'koffi';\r\n\r\n// if (typeof window === 'undefined' && process.platform === 'win32') {\r\n// try {\r\n// const CP_UTF8 = 65001;\r\n// const kernel32 = koffi.load('Kernel32');\r\n// const setConsoleOutputCP = kernel32.func('SetConsoleOutputCP', 'bool', ['int']);\r\n// const setConsoleCP = kernel32.func('SetConsoleCP', 'bool', ['int']);\r\n// setConsoleOutputCP(CP_UTF8);\r\n// setConsoleCP(CP_UTF8);\r\n// } catch (e) {\r\n// console.log(e);\r\n// }\r\n// }\r\n\r\n// export const logger = pino({\r\n// name: process.env.APP_NAME ?? 'iBoot',\r\n// level: process.env.NODE_ENV !== 'production' ? 'debug' : 'info',\r\n// nestedKey: 'payload',\r\n// transport: {\r\n// target: 'pino-pretty',\r\n// options: {\r\n// colorize: true,\r\n// translateTime: 'SYS:yyyy-mm-dd HH:MM:ss',\r\n// ignore: 'pid,hostname',\r\n// messageFormat: '{msg}',\r\n// singleLine: true,\r\n// },\r\n// }\r\n// });\r\n\r\nconst stream = PinoPretty({\r\n colorize: true,\r\n destination: process.stdout,\r\n translateTime: 'SYS:yyyy-mm-dd HH:MM:ss',\r\n ignore: 'pid,hostname',\r\n messageFormat: '{msg}',\r\n singleLine: true,\r\n});\r\n\r\nexport const logger = pino({\r\n name: process.env.APP_NAME ?? 'iBoot',\r\n level: process.env.APP_ENV === 'production' ? 'info' : 'debug',\r\n nestedKey: 'payload'\r\n}, stream);","export const isArray = (obj: unknown) => {\r\n return (\r\n Array.isArray(obj) ||\r\n (typeof obj === \"object\" &&\r\n Object.prototype.toString.call(obj) === \"[object Array]\")\r\n );\r\n};\r\n\r\n/**\r\n * 生成指定长度的随机串\r\n * @param {Object} len\r\n */\r\nexport const randomString = (len: number) => {\r\n const l = len || 32;\r\n const $chars = \"ABCDEFGHJKMNPQRSTWXYZabcdefhijkmnprstwxyz2345678\";\r\n const maxPos = $chars.length;\r\n let pwd = \"\";\r\n for (let i = 0; i < l; i++) {\r\n pwd += $chars.charAt(Math.floor(Math.random() * maxPos));\r\n }\r\n return pwd;\r\n};\r\n\r\nexport const urlParamToJson = (urlQueryParams: string, exclude?: string[]): Record<string, string> => {\r\n const result: Record<string, string> = {};\r\n const strs = urlQueryParams.split(\"&\");\r\n strs.forEach((item) => {\r\n const arr = item.split(\"=\");\r\n if (arr[1]) {\r\n if (!exclude || exclude.indexOf(arr[0]) == -1) {\r\n result[arr[0]] = arr[1];\r\n }\r\n }\r\n });\r\n return result;\r\n};\r\n\r\nexport const urlEncode = (value: string | null | undefined): string => {\r\n if (!value || value == \"\" || value.length == 0) {\r\n return \"\";\r\n }\r\n return (\r\n encodeURIComponent(value)\r\n // .replace(/%20/g, '+')\r\n // .replace(/%2B/g, '\\\\+')\r\n .replace(/\\(/g, \"%28\")\r\n .replace(/\\)/g, \"%29\")\r\n .replace(/\\'/g, \"%27\")\r\n .replace(/\\!/g, \"%21\")\r\n .replace(/\\~/g, \"%7E\")\r\n );\r\n};\r\n\r\nexport const dateFormat = (dt: Date, fmt: string) => {\r\n const o:Record<string, number> = {\r\n \"M+\": dt.getMonth() + 1, //月份\r\n \"d+\": dt.getDate(), //日\r\n \"h+\": dt.getHours(), //小时\r\n \"m+\": dt.getMinutes(), //分\r\n \"s+\": dt.getSeconds(), //秒\r\n \"q+\": Math.floor((dt.getMonth() + 3) / 3), //季度\r\n S: dt.getMilliseconds(), //毫秒\r\n };\r\n if (/(y+)/.test(fmt)){\r\n const regx = new RegExp(/(y+)/);\r\n const value = regx.exec(fmt);\r\n let len = 0;\r\n if(value && value.length > 0){\r\n len = value[0].length;\r\n }\r\n fmt = fmt.replace(/(y+)/, dt.getFullYear() + \"\").substring(4 - len);\r\n }\r\n\r\n for (const k in o){\r\n const s:string = \"(\" + k + \")\";\r\n const regx = new RegExp(s);\r\n if(regx.test(fmt)){\r\n const value = regx.exec(fmt);\r\n let len = 0;\r\n if(value && value.length > 0){\r\n len = value[0].length;\r\n }\r\n fmt = fmt.replace(regx, len == 1 ? o[k].toString() : (\"00\" + o[k]).substring(o[k].toString().length))\r\n }\r\n }\r\n return fmt;\r\n}","import md5 from \"js-md5\";\r\nimport CryptoJS from 'crypto-js';\r\nimport { isArray, randomString, urlEncode, urlParamToJson } from \"./utils\";\r\nimport {\r\n ClientGetParams,\r\n ClientPostParams,\r\n CSRFToken,\r\n CurWebsite,\r\n HttpClientOpts,\r\n HttpHeaders,\r\n HttpToken,\r\n ResultModel,\r\n ServerRequestOptions,\r\n ICookies,\r\n IStorage\r\n} from \"./types/http\";\r\nimport { User, USER_TYPE, USER_TYPE_MAP } from \"./types/user\";\r\nimport { logger } from \"./logger\";\r\n\r\n\r\nexport const DEFAULT_LOCALE = 'zh-CN';\r\nexport const DEVICE_ID_KEY = \"_device_id_key\";\r\nexport const CURRENT_WEBSITE_KEY = \"_current_website_key\"\r\n\r\nconst _GET_ERROR = \"Get request error!\"\r\nconst _POST_ERROR = \"Post request error!\";\r\n\r\nexport const COOKIE_NAMES = {\r\n \"IBOOT_DEVICE_ID\": \"dvid\",\r\n \"IBOOT_LANG\": \"lang\",\r\n \"IBOOT_WEBSITE_ID\": \"wid\",\r\n \"IBOOT_WEBSITE_NO\": \"wno\",\r\n \"IBOOT_TOKEN\": \"token\",\r\n \"IBOOT_USER\": \"user\"\r\n}\r\n\r\nconst HEADER_NAMES = {\r\n \"DEVICE_ID\": \"Device-Id\",\r\n \"LANG\": \"Lang\",\r\n \"WEBSITE_ID\": \"Website-Id\",\r\n \"WEBSITE_NO\": \"Website-No\",\r\n}\r\n\r\n\r\nconst getDefaultRequestHeader = (storage: Readonly<IStorage>): HttpHeaders => {\r\n if (!storage.get) {\r\n throw new Error(\"The get method of IStorage has not been implemented.\")\r\n }\r\n const devideId = storage.get(DEVICE_ID_KEY) ?? ''\r\n const json = storage.get(CURRENT_WEBSITE_KEY);\r\n const curWebsite: CurWebsite | null = json != null ? JSON.parse(json) : null;\r\n const header: HttpHeaders = {}\r\n if (devideId.length > 0) {\r\n header['Device-Id'] = devideId\r\n }\r\n if (curWebsite) {\r\n header['Lang'] = curWebsite.language;\r\n if (curWebsite.websiteId) {\r\n header['Website-Id'] = curWebsite.websiteId;\r\n }\r\n if (curWebsite.websiteNo) {\r\n header['Website-No'] = curWebsite.websiteNo\r\n }\r\n }\r\n return header;\r\n};\r\n\r\n\r\nexport const setDefaultRequestHeader = ({ deviceId, website }: Readonly<{ deviceId: string, website?: CurWebsite }>, storage: IStorage): void => {\r\n if (!storage.set) {\r\n throw new Error(\"The set method of IStorage has not been implemented.\")\r\n }\r\n storage.set(DEVICE_ID_KEY, deviceId);\r\n if (website) {\r\n storage.set(CURRENT_WEBSITE_KEY, JSON.stringify(website));\r\n }\r\n}\r\n\r\nexport const get = async <T>(url: string, opts?: ClientGetParams): Promise<ResultModel<T>> => {\r\n if (opts?.data) {\r\n const params = new URLSearchParams(opts.data);\r\n if (url.indexOf(\"?\") != -1) {\r\n url += `&${params}`\r\n } else {\r\n url += `?${params}`\r\n }\r\n }\r\n const headers: Record<string, string> = (opts && opts.storage && opts.storage.get) ? getDefaultRequestHeader(opts.storage) : {}\r\n const heads = opts?.headers;\r\n if (heads) {\r\n for (const field in heads) {\r\n const value = heads[field];\r\n if (value) {\r\n headers[field] = value;\r\n }\r\n }\r\n }\r\n logger.info({\r\n \"url\": url,\r\n \"headers\": headers,\r\n }, \"GET\")\r\n const res = await fetch(url, {\r\n method: 'GET',\r\n headers: headers,\r\n cache: opts?.useCache ? 'force-cache' : 'default'\r\n });\r\n\r\n if (res.ok) {\r\n const headersMap = Object.fromEntries(res.headers.entries());\r\n const result = { ...await res.json(), headers: headersMap };\r\n logger.debug(result, \"GET_RESULT\")\r\n return result\r\n }\r\n const msg = {\r\n code: res.status,\r\n success: false,\r\n msg: res.statusText\r\n }\r\n logger.error(msg);\r\n return msg;\r\n}\r\n\r\nexport const post = async <T>(url: string, opts?: ClientPostParams): Promise<ResultModel<T>> => {\r\n const data = opts?.data ?? {};\r\n const heads = opts?.headers;\r\n let body: string | FormData;\r\n const defaultHeads = (opts && opts.storage && opts.storage.get) ? getDefaultRequestHeader(opts.storage) : {}\r\n const proxyHeaders = new Headers(defaultHeads);\r\n if (!(data instanceof FormData)) {\r\n body = JSON.stringify(data);\r\n proxyHeaders.set('Content-Type', 'application/json');\r\n } else {\r\n body = data;\r\n }\r\n if (heads) {\r\n for (let field in heads) {\r\n const value = heads[field];\r\n if (value) {\r\n proxyHeaders.set(field, value);\r\n }\r\n }\r\n }\r\n logger.info({\r\n \"url\": url,\r\n \"headers\": proxyHeaders,\r\n }, \"POST\")\r\n const res = await fetch(url, {\r\n method: 'POST',\r\n headers: proxyHeaders,\r\n body: body,\r\n });\r\n if (res.ok) {\r\n const headersMap = Object.fromEntries(res.headers.entries());\r\n const result = { ...await res.json(), headers: headersMap };\r\n logger.debug(result, \"POST_RESULT\")\r\n return result\r\n }\r\n const msg = {\r\n code: res.status,\r\n success: false,\r\n msg: res.statusText,\r\n }\r\n logger.error(msg);\r\n return msg;\r\n}\r\n\r\nexport const iGet = async <T>(url: string, opts?: ClientGetParams): Promise<T | undefined> => {\r\n const res = await get<T>(url, opts);\r\n if (res.success) {\r\n return res.data as T;\r\n }\r\n if (opts?.showError) {\r\n opts.showError(res.msg ?? _GET_ERROR);\r\n return;\r\n }\r\n throw Error(res.msg ?? _GET_ERROR)\r\n}\r\n\r\nexport const iPost = async <T>(url: string, opts?: ClientPostParams): Promise<T | undefined> => {\r\n const res = await post<T>(url, opts);\r\n if (res.success) {\r\n return res.data;\r\n }\r\n if (opts?.showError) {\r\n opts.showError(res.msg ?? _POST_ERROR);\r\n return;\r\n }\r\n throw Error(res.msg ?? _POST_ERROR)\r\n}\r\n\r\nexport const iPostSuccess = async (url: string, opts?: ClientPostParams): Promise<boolean> => {\r\n const res = await post(url, opts);\r\n if (res.success) {\r\n if (opts?.showSuccess) {\r\n opts.showSuccess(res.msg ?? 'SUCCESS')\r\n }\r\n return true;\r\n }\r\n if (opts?.showError) {\r\n opts.showError(res.msg ?? _POST_ERROR);\r\n }\r\n return false;\r\n}\r\n\r\nexport const getHttpOpts = (storage: IStorage): HttpClientOpts => {\r\n if (storage.get) {\r\n const deviceId = storage.get(HEADER_NAMES.DEVICE_ID);\r\n const lang = storage.get(HEADER_NAMES.LANG);\r\n const websiteId = storage.get(HEADER_NAMES.WEBSITE_ID);\r\n const websiteNo = storage.get(HEADER_NAMES.WEBSITE_NO);\r\n const result: HttpClientOpts = {}\r\n if (deviceId && deviceId.length > 0) {\r\n result.deviceId = deviceId;\r\n }\r\n if (lang && lang.length > 0) {\r\n result.lang = lang\r\n }\r\n if (websiteId && websiteId.length > 0) {\r\n result.websiteId = websiteId\r\n }\r\n if (websiteNo && websiteNo.length > 0) {\r\n result.websiteNo = websiteNo\r\n }\r\n return result;\r\n }\r\n throw new Error(\"The set method of IStorage has not been implemented.\")\r\n}\r\n\r\nexport const getLoginUser = (cookies: ICookies): User | undefined => {\r\n if (cookies.get) {\r\n const userjson = cookies.get(COOKIE_NAMES.IBOOT_USER)\r\n if (userjson && userjson.length > 0) {\r\n return JSON.parse(userjson);\r\n }\r\n }\r\n return undefined\r\n}\r\n\r\nexport const getToken = (cookies: ICookies): HttpToken | undefined => {\r\n if (cookies.get) {\r\n const userjson = cookies.get(COOKIE_NAMES.IBOOT_USER);\r\n if (userjson && userjson.length > 0) {\r\n const user = JSON.parse(userjson);\r\n const username = user.username;\r\n const utype = user.userType.toString();\r\n const token = cookies.get(COOKIE_NAMES.IBOOT_TOKEN);\r\n if (token) {\r\n return {\r\n \"username\": username,\r\n \"utype\": utype,\r\n \"token\": token\r\n }\r\n }\r\n }\r\n }\r\n return undefined\r\n}\r\n\r\nexport const setToken = (data: User & { token: string }, cookies: ICookies): void => {\r\n const { id, name, username, nickname, headImg, token, lastLoginTime, deviceId, userType, mustChangePwd } = data;\r\n const loginUser: User = {\r\n id: id,\r\n name: name,\r\n username: username,\r\n nickname: nickname || name,\r\n headImg: headImg,\r\n lastLoginTime: lastLoginTime,\r\n deviceId: deviceId,\r\n userType: userType,\r\n accountType: 0,\r\n needToReview: false,\r\n socketOnline: false,\r\n mustChangePwd: mustChangePwd\r\n };\r\n if (!cookies.set) {\r\n throw new Error('cookies set function is undefined')\r\n }\r\n cookies.set(COOKIE_NAMES.IBOOT_TOKEN, token, {\r\n path: '/',\r\n secure: process.env.APP_ENV === 'production',\r\n httpOnly: true,\r\n sameSite: 'strict'\r\n });\r\n cookies.set(COOKIE_NAMES.IBOOT_USER, JSON.stringify(loginUser))\r\n}\r\n\r\nexport const cleanToken = (cookies: ICookies): void => {\r\n if (!cookies.set) {\r\n throw new Error('cookies set function is undefined')\r\n }\r\n cookies.set(COOKIE_NAMES.IBOOT_TOKEN, '', {\r\n maxAge: -1, //设置为 -1表示立即过期\r\n httpOnly: true,\r\n path: '/',\r\n });\r\n cookies.set(COOKIE_NAMES.IBOOT_USER, '', {\r\n maxAge: -1, //设置为 -1表示立即过期\r\n httpOnly: true,\r\n path: '/',\r\n });\r\n if (!cookies.delete) {\r\n throw new Error('cookies delete function is undefined')\r\n }\r\n cookies.delete(COOKIE_NAMES.IBOOT_TOKEN);\r\n cookies.delete(COOKIE_NAMES.IBOOT_USER);\r\n}\r\n\r\nexport class HttpClient {\r\n private readonly baseUrl: string;\r\n private readonly helloMethod: string;\r\n private readonly apiKey: string;\r\n private readonly userType: USER_TYPE;\r\n private readonly userFrom: string;\r\n private readonly deviceId: string;\r\n private readonly version: string = '1';\r\n private readonly lang: string;\r\n private readonly websiteId?: string;\r\n private readonly websiteNo?: string;\r\n constructor(opts: Readonly<HttpClientOpts>) {\r\n const isProduction = process.env.APP_ENV === 'production';\r\n if (!isProduction) {\r\n logger.warn(\"This is currently a development environment!\")\r\n }\r\n this.baseUrl = process.env.APP_BASEURL!;\r\n this.apiKey = process.env.APP_APIKEY!;\r\n this.userFrom = process.env.APP_USERFROM ?? '1';\r\n\r\n this.helloMethod = opts.helloURL ?? ''\r\n this.userType = opts.userType ?? USER_TYPE_MAP.TYPE_MGT;\r\n this.deviceId = opts.deviceId ?? randomString(10);\r\n this.lang = opts.lang ?? DEFAULT_LOCALE;\r\n this.websiteId = opts.websiteId\r\n this.websiteNo = opts.websiteNo\r\n }\r\n\r\n encrypt(data: string) {\r\n const key = CryptoJS.enc.Utf8.parse(this.apiKey);\r\n return CryptoJS.AES.encrypt(data, key).toString();\r\n }\r\n\r\n decrypt(data: string) {\r\n const key = CryptoJS.enc.Utf8.parse(this.apiKey);\r\n return CryptoJS.AES.decrypt(data, key, {\r\n mode: CryptoJS.mode.ECB,\r\n }).toString(CryptoJS.enc.Utf8);\r\n }\r\n\r\n //eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n private convertUrlParameter(data: Record<string, any>): string {\r\n const p: string[] = [];\r\n for (const o in data) {\r\n let v = data[o];\r\n if (v && typeof v === \"string\") {\r\n v = v.trim();\r\n } else if (v && typeof v === \"object\") {\r\n if (isArray(v)) {\r\n if (v.length === 0) {\r\n continue;\r\n }\r\n for (let i = 0; i < v.length; i++) {\r\n const arr_item = v[i];\r\n for (const item_field in arr_item) {\r\n const item_field_value = arr_item[item_field] ?? undefined;\r\n if (item_field_value) {\r\n if (typeof item_field_value === \"object\") {\r\n if (isArray(item_field_value)) {\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n item_field_value.forEach((item1: any, index: number) => {\r\n if (item1) {\r\n for (const f in item1) {\r\n const v = item1[f];\r\n if (v && v.toString().length > 0) {\r\n const s = `[${i.toString()}].${item_field + `[${index.toString()}].${f}`}=${urlEncode(v)}`;\r\n p.push(o + s);\r\n }\r\n }\r\n }\r\n });\r\n }\r\n } else if (item_field_value.toString().length > 0) {\r\n const s = `[${i.toString()}].${item_field}=${urlEncode(item_field_value.toString())}`;\r\n p.push(o + s);\r\n }\r\n }\r\n }\r\n }\r\n } else {\r\n for (const obj in v) {\r\n const oValue = v[obj];\r\n if (oValue != null && oValue != \"\" && oValue.length != 0) {\r\n const s = `.${obj}=${urlEncode(oValue)}`;\r\n p.push(o + s);\r\n }\r\n }\r\n }\r\n continue;\r\n } else if (v && typeof v === \"function\") {\r\n v = null;\r\n }\r\n\r\n if (v != null && v != \"\" && v.length != 0) {\r\n p.push(o + \"=\" + urlEncode(v));\r\n }\r\n }\r\n return (p && p.join(\"&\"));\r\n }\r\n\r\n private async sign(data: Record<string, object | string>): Promise<string> {\r\n //由后台分配\r\n const _apiKey = \"&key=\" + (await this.helloIboot());\r\n const arr: string[] = [];\r\n for (const o in data) {\r\n arr.push(o);\r\n }\r\n arr.sort((a: string, b: string) => {\r\n return a.toLowerCase().localeCompare(b.toLowerCase());\r\n });\r\n const res: string[] = [];\r\n arr.forEach((v: string) => {\r\n let value: object | string = data[v];\r\n if (typeof value === \"object\") {\r\n value = JSON.stringify(value);\r\n }\r\n res.push(v + \"=\" + value);\r\n });\r\n const paramsStr: string = res.join(\"&\");\r\n const str = md5.md5((paramsStr + _apiKey).toLocaleUpperCase());\r\n const logInfo = {\r\n params: paramsStr,\r\n md5: str\r\n }\r\n logger.debug(logInfo, \"API_SIGN\")\r\n return str;\r\n }\r\n\r\n //eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n private assemblyParameter(data?: Record<string, any>, username?: string): Record<string, any> {\r\n const params = data ?? {};\r\n params['timestamp'] = Date.now() + '';\r\n params['echostr'] = randomString(10);\r\n params['version'] = this.version;\r\n params['deviceId'] = this.deviceId;\r\n params['webid'] = this.websiteId;\r\n params['apiKey'] = this.apiKey;\r\n if (username && username.length > 0) {\r\n params['username'] = username;\r\n }\r\n return params;\r\n }\r\n\r\n private async assemblyHeader({ urlParams, token }: Readonly<{ urlParams: string, token?: Readonly<HttpToken> }>) {\r\n const h: Record<string, string> = {\r\n 'Content-Type': 'application/x-www-form-urlencoded',\r\n 'Res-Type': 'json',\r\n 'Device-Id': this.deviceId,\r\n 'User-Type': token?.utype.toString() ?? this.userType.toString(),\r\n 'User-From': this.userFrom,\r\n 'Api-Key': this.apiKey\r\n }\r\n if (this.lang && this.lang.length > 0) {\r\n h['Lang'] = this.lang\r\n }\r\n if (this.websiteId && this.websiteId.length > 0) {\r\n h['Web-Id'] = this.websiteId\r\n }\r\n if (this.websiteNo && this.websiteNo.length > 0) {\r\n h['Web-No'] = this.websiteNo\r\n }\r\n if (token) {\r\n if (token.token && token.token.length > 0 && token.username && token.username.length > 0) {\r\n h['Authorization'] = token.token;\r\n h['Username'] = token.username;\r\n }\r\n if (token.xcsrf) {\r\n h[token.xcsrf.csrfHeader] = token.xcsrf.csrfToken;\r\n }\r\n }\r\n const data = urlParamToJson(urlParams);\r\n const sign = await this.sign(data);\r\n h['Sign'] = sign\r\n return h;\r\n }\r\n\r\n private async helloIboot(): Promise<string> {\r\n if (this.helloMethod.length <= 0) {\r\n return this.apiKey;\r\n }\r\n const api = this.getApiUrl(this.helloMethod);\r\n const h = {\r\n 'Content-Type': 'application/x-www-form-urlencoded',\r\n 'Res-Type': 'json',\r\n 'Api-Key': this.apiKey\r\n }\r\n const logInfo = {\r\n \"url\": api,\r\n \"headers\": h\r\n }\r\n logger.debug(logInfo, \"HELLO\");\r\n const res = await fetch(api, {\r\n method: 'GET',\r\n headers: h,\r\n credentials: 'include',\r\n cache: 'force-cache'\r\n });\r\n if (res.ok) {\r\n const result = await res.json();\r\n logger.debug(result.data, 'HELLO RESULT')\r\n return result.data;\r\n }\r\n throw new Error('hello iBoot error!')\r\n }\r\n\r\n private getApiUrl(url: string): string {\r\n return `${this.baseUrl}/${url}`;\r\n }\r\n\r\n async csrf(): Promise<string | undefined> {\r\n const res = await this.get<CSRFToken>({\r\n url: 'guest/csrf'\r\n });\r\n if (res.success) {\r\n const data = res.data;\r\n if (data) {\r\n return data[\"csrfToken\"].toString();\r\n }\r\n }\r\n return undefined;\r\n }\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n async get<T>({ url, data, token, cache = 'default' }: Readonly<ServerRequestOptions>): Promise<ResultModel<T>> {\r\n const params = this.assemblyParameter(data);\r\n const urlParams = this.convertUrlParameter(params);\r\n const headers = await this.assemblyHeader({ \"urlParams\": urlParams, \"token\": token });\r\n const api = `${this.getApiUrl(url)}?${urlParams.toString()}`\r\n const logInfo = {\r\n \"url\": api,\r\n \"headers\": headers\r\n }\r\n logger.info(logInfo, \"GET\");\r\n const res = await fetch(api, {\r\n \"method\": 'GET',\r\n \"headers\": headers,\r\n \"credentials\": 'include',\r\n \"cache\": cache\r\n });\r\n if (res.ok) {\r\n const headersMap = Object.fromEntries(res.headers.entries());\r\n const result = { ...await res.json(), headers: headersMap };\r\n logger.debug(result, \"GET_RESULT\")\r\n return result;\r\n }\r\n const msg = {\r\n code: res.status,\r\n success: false,\r\n msg: res.statusText\r\n }\r\n logger.error(msg);\r\n return msg;\r\n }\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n async post<T>({ url, data, token, cache = \"default\" }: Readonly<ServerRequestOptions>): Promise<ResultModel<T>> {\r\n data = data ? { ...data } : {}\r\n const buffer = data.buffer ?? undefined;\r\n const boundary = data.boundary ?? undefined;\r\n if (buffer) {\r\n delete data.buffer;\r\n }\r\n if (boundary) {\r\n delete data.boundary;\r\n }\r\n const params = this.assemblyParameter(data);\r\n const urlParams = this.convertUrlParameter(params);\r\n const headers = await this.assemblyHeader({ \"urlParams\": urlParams, \"token\": token });\r\n if (buffer && boundary) {\r\n headers['Content-Type'] = `multipart/form-data; boundary=${boundary}`;\r\n }\r\n const api = this.getApiUrl(url);\r\n const logInfo = {\r\n \"url\": api,\r\n \"headers\": headers,\r\n \"params\": params\r\n }\r\n logger.info(logInfo, \"POST\");\r\n const urls = buffer ? `${api}?${urlParams}` : api;\r\n const res = await fetch(urls, {\r\n \"method\": 'POST',\r\n \"headers\": headers,\r\n \"body\": buffer ? buffer : urlParams.toString(),\r\n \"credentials\": 'include',\r\n \"cache\": cache\r\n });\r\n if (res.ok) {\r\n const headersMap = Object.fromEntries(res.headers.entries());\r\n const result = { ...await res.json(), headers: headersMap };\r\n logger.debug(result, \"POST_RESULT\");\r\n return result;\r\n }\r\n const msg = {\r\n code: res.status,\r\n success: false,\r\n msg: res.statusText\r\n }\r\n logger.error(msg);\r\n return msg;\r\n }\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n async stream({ url, data, token }: Readonly<Omit<ServerRequestOptions, 'cache'>>): Promise<Response> {\r\n data = data ? { ...data } : {}\r\n const buffer = data.buffer ?? undefined;\r\n const boundary = data.boundary ?? undefined;\r\n if (buffer) {\r\n delete data.buffer;\r\n }\r\n if (boundary) {\r\n delete data.boundary;\r\n }\r\n const params = this.assemblyParameter(data);\r\n const urlParams = this.convertUrlParameter(params); //new URLSearchParams(params);\r\n\r\n const headers = await this.assemblyHeader({ \"urlParams\": urlParams, \"token\": token });\r\n if (buffer && boundary) {\r\n headers['Content-Type'] = `multipart/form-data; boundary=${boundary}`;\r\n }\r\n headers['Connection'] = 'keep-alive';\r\n headers['X-Accel-Buffering'] = 'no'; //防止 Nginx 缓存\r\n headers['Cache-Control'] = 'no-cache';\r\n const api = this.getApiUrl(url)\r\n try {\r\n const url = buffer ? `${api}?${urlParams}` : api;\r\n const logInfo = {\r\n \"url\": api,\r\n \"headers\": headers,\r\n \"params\": params\r\n }\r\n logger.info(logInfo, \"STREAM\");\r\n const res = await fetch(url, {\r\n method: 'POST',\r\n headers: headers,\r\n body: buffer ? buffer : urlParams.toString(),\r\n credentials: 'include'\r\n });\r\n\r\n if (!res.ok) {\r\n throw new Error(`HTTP error! status: ${res.status}`);\r\n }\r\n if (!res.body) {\r\n throw new Error('No response body');\r\n }\r\n const headersMap = Object.fromEntries(res.headers.entries());\r\n return new Response(res.body, {\r\n headers: headersMap\r\n });\r\n } catch (e) {\r\n throw e;\r\n }\r\n }\r\n}"],"names":["ACCOUNT_TYPE_MAP","USER_TYPE_MAP","USER_FORM_MAP","USER_SEX_MAP","stream","PinoPretty","logger","pino","isArray","obj","randomString","len","l","$chars","maxPos","pwd","i","urlParamToJson","urlQueryParams","exclude","result","item","arr","urlEncode","value","dateFormat","dt","fmt","o","k","regx","DEFAULT_LOCALE","DEVICE_ID_KEY","CURRENT_WEBSITE_KEY","_GET_ERROR","_POST_ERROR","COOKIE_NAMES","HEADER_NAMES","getDefaultRequestHeader","storage","devideId","json","curWebsite","header","setDefaultRequestHeader","deviceId","website","get","url","opts","params","headers","heads","field","res","headersMap","msg","post","data","body","defaultHeads","proxyHeaders","iGet","iPost","iPostSuccess","getHttpOpts","lang","websiteId","websiteNo","getLoginUser","cookies","userjson","getToken","user","username","utype","token","setToken","id","name","nickname","headImg","lastLoginTime","userType","mustChangePwd","loginUser","cleanToken","HttpClient","key","CryptoJS","p","v","arr_item","item_field","item_field_value","item1","index","f","s","oValue","_apiKey","a","b","paramsStr","str","md5","logInfo","urlParams","h","sign","api","cache","buffer","boundary","urls","e"],"mappings":";;;;AAAO,MAAMA,IAAmB;AAAA,EAC5B,SAAU;AAAA,EACV,OAAQ;AAAA,EACR,OAAQ;AACZ,GAEaC,IAAgB;AAAA,EACzB,UAAW;AAAA,EACX,QAAS;AAAA,EACT,QAAS;AACb,GAEaC,IAAgB;AAAA,EACzB,UAAW;AAAA,EACX,SAAU;AAAA,EACV,kBAAmB;AAAA,EACnB,aAAc;AAAA,EACd,WAAY;AAAA,EACZ,UAAW;AAAA,EACX,aAAc;AAClB,GAEaC,IAAe;AAAA,EACxB,SAAQ;AAAA,EACR,MAAK;AAAA,EACL,QAAO;AACX,GCOMC,IAASC,EAAW;AAAA,EACtB,UAAU;AAAA,EACV,aAAa,QAAQ;AAAA,EACrB,eAAe;AAAA,EACf,QAAQ;AAAA,EACR,eAAe;AAAA,EACf,YAAY;AAChB,CAAC,GAEYC,IAASC,EAAK;AAAA,EACvB,MAAM,QAAQ,IAAI,YAAY;AAAA,EAC9B,OAAO,QAAQ,IAAI,YAAY,eAAe,SAAS;AAAA,EACvD,WAAW;AACf,GAAGH,CAAM,GC9CII,IAAU,CAACC,MAEpB,MAAM,QAAQA,CAAG,KAChB,OAAOA,KAAQ,YACd,OAAO,UAAU,SAAS,KAAKA,CAAG,MAAM,kBAQjCC,IAAe,CAACC,MAAgB;AAC3C,QAAMC,IAAID,KAAO,IACXE,IAAS,oDACTC,IAASD,EAAO;AACtB,MAAIE,IAAM;AACV,WAASC,IAAI,GAAGA,IAAIJ,GAAGI;AACrB,IAAAD,KAAOF,EAAO,OAAO,KAAK,MAAM,KAAK,WAAWC,CAAM,CAAC;AAEzD,SAAOC;AACT,GAEaE,IAAiB,CAACC,GAAwBC,MAA+C;AACpG,QAAMC,IAAiC,CAAA;AAEvC,SADaF,EAAe,MAAM,GAAG,EAChC,QAAQ,CAACG,MAAS;AACrB,UAAMC,IAAMD,EAAK,MAAM,GAAG;AAC1B,IAAIC,EAAI,CAAC,MACH,CAACH,KAAWA,EAAQ,QAAQG,EAAI,CAAC,CAAC,KAAK,QACzCF,EAAOE,EAAI,CAAC,CAAC,IAAIA,EAAI,CAAC;AAAA,EAG5B,CAAC,GACMF;AACT,GAEaG,IAAY,CAACC,MACpB,CAACA,KAASA,KAAS,MAAMA,EAAM,UAAU,IACpC,KAGP,mBAAmBA,CAAK,EAGrB,QAAQ,OAAO,KAAK,EACpB,QAAQ,OAAO,KAAK,EACpB,QAAQ,OAAO,KAAK,EACpB,QAAQ,OAAO,KAAK,EACpB,QAAQ,OAAO,KAAK,GAIdC,IAAa,CAACC,GAAUC,MAAgB;AACjD,QAAMC,IAA2B;AAAA,IAC7B,MAAMF,EAAG,SAAA,IAAa;AAAA;AAAA,IACtB,MAAMA,EAAG,QAAA;AAAA;AAAA,IACT,MAAMA,EAAG,SAAA;AAAA;AAAA,IACT,MAAMA,EAAG,WAAA;AAAA;AAAA,IACT,MAAMA,EAAG,WAAA;AAAA;AAAA,IACT,MAAM,KAAK,OAAOA,EAAG,SAAA,IAAa,KAAK,CAAC;AAAA;AAAA,IACxC,GAAGA,EAAG,gBAAA;AAAA;AAAA,EAAgB;AAE1B,MAAI,OAAO,KAAKC,CAAG,GAAE;AAEjB,UAAMH,IADO,IAAI,OAAO,MAAM,EACX,KAAKG,CAAG;AAC3B,QAAIhB,IAAM;AACV,IAAGa,KAASA,EAAM,SAAS,MACvBb,IAAMa,EAAM,CAAC,EAAE,SAEnBG,IAAMA,EAAI,QAAQ,QAAQD,EAAG,YAAA,IAAgB,EAAE,EAAE,UAAU,IAAIf,CAAG;AAAA,EACtE;AAEA,aAAWkB,KAAKD,GAAE;AACd,UAAM,IAAW,MAAMC,IAAI,KACrBC,IAAO,IAAI,OAAO,CAAC;AACzB,QAAGA,EAAK,KAAKH,CAAG,GAAE;AACd,YAAMH,IAAQM,EAAK,KAAKH,CAAG;AAC3B,UAAIhB,IAAM;AACV,MAAGa,KAASA,EAAM,SAAS,MACvBb,IAAMa,EAAM,CAAC,EAAE,SAEnBG,IAAMA,EAAI,QAAQG,GAAMnB,KAAO,IAAIiB,EAAEC,CAAC,EAAE,SAAA,KAAc,OAAOD,EAAEC,CAAC,GAAG,UAAUD,EAAEC,CAAC,EAAE,WAAW,MAAM,CAAC;AAAA,IACxG;AAAA,EACJ;AACA,SAAOF;AACX,GClEaI,IAAiB,SACjBC,IAAgB,kBAChBC,IAAsB,wBAE7BC,IAAa,sBACbC,IAAc,uBAEPC,IAAe;AAAA,EACxB,iBAAmB;AAAA,EACnB,YAAc;AAAA,EACd,kBAAoB;AAAA,EACpB,kBAAoB;AAAA,EACpB,aAAe;AAAA,EACf,YAAc;AAClB,GAEMC,IAAe;AAAA,EACjB,WAAa;AAAA,EACb,MAAQ;AAAA,EACR,YAAc;AAAA,EACd,YAAc;AAClB,GAGMC,IAA0B,CAACC,MAA6C;AAC1E,MAAI,CAACA,EAAQ;AACT,UAAM,IAAI,MAAM,sDAAsD;AAE1E,QAAMC,IAAWD,EAAQ,IAAIP,CAAa,KAAK,IACzCS,IAAOF,EAAQ,IAAIN,CAAmB,GACtCS,IAAgCD,KAAQ,OAAO,KAAK,MAAMA,CAAI,IAAI,MAClEE,IAAsB,CAAA;AAC5B,SAAIH,EAAS,SAAS,MAClBG,EAAO,WAAW,IAAIH,IAEtBE,MACAC,EAAO,OAAUD,EAAW,UACxBA,EAAW,cACXC,EAAO,YAAY,IAAID,EAAW,YAElCA,EAAW,cACXC,EAAO,YAAY,IAAID,EAAW,aAGnCC;AACX,GAGaC,IAA0B,CAAC,EAAE,UAAAC,GAAU,SAAAC,EAAA,GAAiEP,MAA4B;AAC7I,MAAI,CAACA,EAAQ;AACT,UAAM,IAAI,MAAM,sDAAsD;AAE1E,EAAAA,EAAQ,IAAIP,GAAea,CAAQ,GAC/BC,KACAP,EAAQ,IAAIN,GAAqB,KAAK,UAAUa,CAAO,CAAC;AAEhE,GAEaC,IAAM,OAAUC,GAAaC,MAAoD;AAC1F,MAAIA,GAAM,MAAM;AACZ,UAAMC,IAAS,IAAI,gBAAgBD,EAAK,IAAI;AAC5C,IAAID,EAAI,QAAQ,GAAG,KAAK,KACpBA,KAAO,IAAIE,CAAM,KAEjBF,KAAO,IAAIE,CAAM;AAAA,EAEzB;AACA,QAAMC,IAAmCF,KAAQA,EAAK,WAAWA,EAAK,QAAQ,MAAOX,EAAwBW,EAAK,OAAO,IAAI,CAAA,GACvHG,IAAQH,GAAM;AACpB,MAAIG;AACA,eAAWC,KAASD,GAAO;AACvB,YAAM5B,IAAQ4B,EAAMC,CAAK;AACzB,MAAI7B,MACA2B,EAAQE,CAAK,IAAI7B;AAAA,IAEzB;AAEJ,EAAAlB,EAAO,KAAK;AAAA,IACR,KAAO0C;AAAA,IACP,SAAWG;AAAA,EAAA,GACZ,KAAK;AACR,QAAMG,IAAM,MAAM,MAAMN,GAAK;AAAA,IACzB,QAAQ;AAAA,IACR,SAAAG;AAAA,IACA,OAAOF,GAAM,WAAW,gBAAgB;AAAA,EAAA,CAC3C;AAED,MAAIK,EAAI,IAAI;AACR,UAAMC,IAAa,OAAO,YAAYD,EAAI,QAAQ,SAAS,GACrDlC,IAAS,EAAE,GAAG,MAAMkC,EAAI,KAAA,GAAQ,SAASC,EAAA;AAC/C,WAAAjD,EAAO,MAAMc,GAAQ,YAAY,GAC1BA;AAAA,EACX;AACA,QAAMoC,IAAM;AAAA,IACR,MAAMF,EAAI;AAAA,IACV,SAAS;AAAA,IACT,KAAKA,EAAI;AAAA,EAAA;AAEb,SAAAhD,EAAO,MAAMkD,CAAG,GACTA;AACX,GAEaC,IAAO,OAAUT,GAAaC,MAAqD;AAC5F,QAAMS,IAAOT,GAAM,QAAQ,CAAA,GACrBG,IAAQH,GAAM;AACpB,MAAIU;AACJ,QAAMC,IAAgBX,KAAQA,EAAK,WAAWA,EAAK,QAAQ,MAAOX,EAAwBW,EAAK,OAAO,IAAI,CAAA,GACpGY,IAAe,IAAI,QAAQD,CAAY;AAO7C,MANMF,aAAgB,WAIlBC,IAAOD,KAHPC,IAAO,KAAK,UAAUD,CAAI,GAC1BG,EAAa,IAAI,gBAAgB,kBAAkB,IAInDT;AACA,aAASC,KAASD,GAAO;AACrB,YAAM5B,IAAQ4B,EAAMC,CAAK;AACzB,MAAI7B,KACAqC,EAAa,IAAIR,GAAO7B,CAAK;AAAA,IAErC;AAEJ,EAAAlB,EAAO,KAAK;AAAA,IACR,KAAO0C;AAAA,IACP,SAAWa;AAAA,EAAA,GACZ,MAAM;AACT,QAAMP,IAAM,MAAM,MAAMN,GAAK;AAAA,IACzB,QAAQ;AAAA,IACR,SAASa;AAAA,IACT,MAAAF;AAAA,EAAA,CACH;AACD,MAAIL,EAAI,IAAI;AACR,UAAMC,IAAa,OAAO,YAAYD,EAAI,QAAQ,SAAS,GACrDlC,IAAS,EAAE,GAAG,MAAMkC,EAAI,KAAA,GAAQ,SAASC,EAAA;AAC/C,WAAAjD,EAAO,MAAMc,GAAQ,aAAa,GAC3BA;AAAA,EACX;AACA,QAAMoC,IAAM;AAAA,IACR,MAAMF,EAAI;AAAA,IACV,SAAS;AAAA,IACT,KAAKA,EAAI;AAAA,EAAA;AAEb,SAAAhD,EAAO,MAAMkD,CAAG,GACTA;AACX,GAEaM,IAAO,OAAUd,GAAaC,MAAmD;AAC1F,QAAMK,IAAM,MAAMP,EAAOC,GAAKC,CAAI;AAClC,MAAIK,EAAI;AACJ,WAAOA,EAAI;AAEf,MAAIL,GAAM,WAAW;AACjB,IAAAA,EAAK,UAAUK,EAAI,OAAOpB,CAAU;AACpC;AAAA,EACJ;AACA,QAAM,MAAMoB,EAAI,OAAOpB,CAAU;AACrC,GAEa6B,IAAQ,OAAUf,GAAaC,MAAoD;AAC5F,QAAMK,IAAM,MAAMG,EAAQT,GAAKC,CAAI;AACnC,MAAIK,EAAI;AACJ,WAAOA,EAAI;AAEf,MAAIL,GAAM,WAAW;AACjB,IAAAA,EAAK,UAAUK,EAAI,OAAOnB,CAAW;AACrC;AAAA,EACJ;AACA,QAAM,MAAMmB,EAAI,OAAOnB,CAAW;AACtC,GAEa6B,IAAe,OAAOhB,GAAaC,MAA8C;AAC1F,QAAMK,IAAM,MAAMG,EAAKT,GAAKC,CAAI;AAChC,SAAIK,EAAI,WACAL,GAAM,eACNA,EAAK,YAAYK,EAAI,OAAO,SAAS,GAElC,OAEPL,GAAM,aACNA,EAAK,UAAUK,EAAI,OAAOnB,CAAW,GAElC;AACX,GAEa8B,IAAc,CAAC1B,MAAsC;AAC9D,MAAIA,EAAQ,KAAK;AACb,UAAMM,IAAWN,EAAQ,IAAIF,EAAa,SAAS,GAC7C6B,IAAO3B,EAAQ,IAAIF,EAAa,IAAI,GACpC8B,IAAY5B,EAAQ,IAAIF,EAAa,UAAU,GAC/C+B,IAAY7B,EAAQ,IAAIF,EAAa,UAAU,GAC/CjB,IAAyB,CAAA;AAC/B,WAAIyB,KAAYA,EAAS,SAAS,MAC9BzB,EAAO,WAAWyB,IAElBqB,KAAQA,EAAK,SAAS,MACtB9C,EAAO,OAAO8C,IAEdC,KAAaA,EAAU,SAAS,MAChC/C,EAAO,YAAY+C,IAEnBC,KAAaA,EAAU,SAAS,MAChChD,EAAO,YAAYgD,IAEhBhD;AAAA,EACX;AACC,QAAM,IAAI,MAAM,sDAAsD;AAC3E,GAEaiD,IAAe,CAACC,MAAwC;AACjE,MAAIA,EAAQ,KAAK;AACb,UAAMC,IAAWD,EAAQ,IAAIlC,EAAa,UAAU;AACpD,QAAImC,KAAYA,EAAS,SAAS;AAC9B,aAAO,KAAK,MAAMA,CAAQ;AAAA,EAElC;AAEJ,GAEaC,IAAW,CAACF,MAA6C;AAClE,MAAIA,EAAQ,KAAK;AACb,UAAMC,IAAWD,EAAQ,IAAIlC,EAAa,UAAU;AACpD,QAAImC,KAAYA,EAAS,SAAS,GAAG;AACjC,YAAME,IAAO,KAAK,MAAMF,CAAQ,GAC1BG,IAAWD,EAAK,UAChBE,IAAQF,EAAK,SAAS,SAAA,GACtBG,IAAQN,EAAQ,IAAIlC,EAAa,WAAW;AAClD,UAAIwC;AACA,eAAO;AAAA,UACH,UAAYF;AAAA,UACZ,OAASC;AAAA,UACT,OAASC;AAAA,QAAA;AAAA,IAGrB;AAAA,EACJ;AAEJ,GAEaC,IAAW,CAACnB,GAAgCY,MAA4B;AACjF,QAAM,EAAE,IAAAQ,GAAI,MAAAC,GAAM,UAAAL,GAAU,UAAAM,GAAU,SAAAC,GAAS,OAAAL,GAAO,eAAAM,GAAe,UAAArC,GAAU,UAAAsC,GAAU,eAAAC,EAAA,IAAkB1B,GACrG2B,IAAkB;AAAA,IACpB,IAAAP;AAAA,IACA,MAAAC;AAAA,IACA,UAAAL;AAAA,IACA,UAAUM,KAAYD;AAAA,IACtB,SAAAE;AAAA,IACA,eAAAC;AAAA,IACA,UAAArC;AAAA,IACA,UAAAsC;AAAA,IACA,aAAa;AAAA,IACb,cAAc;AAAA,IACd,cAAc;AAAA,IACd,eAAAC;AAAA,EAAA;AAEJ,MAAI,CAACd,EAAQ;AACT,UAAM,IAAI,MAAM,mCAAmC;AAEvD,EAAAA,EAAQ,IAAIlC,EAAa,aAAawC,GAAO;AAAA,IACzC,MAAM;AAAA,IACN,QAAQ,QAAQ,IAAI,YAAY;AAAA,IAChC,UAAU;AAAA,IACV,UAAU;AAAA,EAAA,CACb,GACDN,EAAQ,IAAIlC,EAAa,YAAY,KAAK,UAAUiD,CAAS,CAAC;AAClE,GAEaC,KAAa,CAAChB,MAA4B;AACnD,MAAI,CAACA,EAAQ;AACT,UAAM,IAAI,MAAM,mCAAmC;AAYvD,MAVAA,EAAQ,IAAIlC,EAAa,aAAa,IAAI;AAAA,IACtC,QAAQ;AAAA;AAAA,IACR,UAAU;AAAA,IACV,MAAM;AAAA,EAAA,CACT,GACDkC,EAAQ,IAAIlC,EAAa,YAAY,IAAI;AAAA,IACrC,QAAQ;AAAA;AAAA,IACR,UAAU;AAAA,IACV,MAAM;AAAA,EAAA,CACT,GACG,CAACkC,EAAQ;AACT,UAAM,IAAI,MAAM,sCAAsC;AAE1D,EAAAA,EAAQ,OAAOlC,EAAa,WAAW,GACvCkC,EAAQ,OAAOlC,EAAa,UAAU;AAC1C;AAEO,MAAMmD,GAAW;AAAA,EACH;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA,UAAkB;AAAA,EAClB;AAAA,EACA;AAAA,EACA;AAAA,EACjB,YAAYtC,GAAgC;AAExC,IADqB,QAAQ,IAAI,YAAY,gBAEzC3C,EAAO,KAAK,8CAA8C,GAE9D,KAAK,UAAU,QAAQ,IAAI,aAC3B,KAAK,SAAS,QAAQ,IAAI,YAC1B,KAAK,WAAW,QAAQ,IAAI,gBAAgB,KAE5C,KAAK,cAAc2C,EAAK,YAAY,IACpC,KAAK,WAAWA,EAAK,YAAYhD,EAAc,UAC/C,KAAK,WAAWgD,EAAK,YAAYvC,EAAa,EAAE,GAChD,KAAK,OAAOuC,EAAK,QAAQlB,GACzB,KAAK,YAAYkB,EAAK,WACtB,KAAK,YAAYA,EAAK;AAAA,EAC1B;AAAA,EAEA,QAAQS,GAAc;AAClB,UAAM8B,IAAMC,EAAS,IAAI,KAAK,MAAM,KAAK,MAAM;AAC/C,WAAOA,EAAS,IAAI,QAAQ/B,GAAM8B,CAAG,EAAE,SAAA;AAAA,EAC3C;AAAA,EAEA,QAAQ9B,GAAc;AAClB,UAAM8B,IAAMC,EAAS,IAAI,KAAK,MAAM,KAAK,MAAM;AAC/C,WAAOA,EAAS,IAAI,QAAQ/B,GAAM8B,GAAK;AAAA,MACnC,MAAMC,EAAS,KAAK;AAAA,IAAA,CACvB,EAAE,SAASA,EAAS,IAAI,IAAI;AAAA,EACjC;AAAA;AAAA,EAGQ,oBAAoB/B,GAAmC;AAC3D,UAAMgC,IAAc,CAAA;AACpB,eAAW9D,KAAK8B,GAAM;AAClB,UAAIiC,IAAIjC,EAAK9B,CAAC;AACd,UAAI+D,KAAK,OAAOA,KAAM;AAClB,QAAAA,IAAIA,EAAE,KAAA;AAAA,eACCA,KAAK,OAAOA,KAAM,UAAU;AACnC,YAAInF,EAAQmF,CAAC,GAAG;AACZ,cAAIA,EAAE,WAAW;AACb;AAEJ,mBAAS3E,IAAI,GAAGA,IAAI2E,EAAE,QAAQ3E,KAAK;AAC/B,kBAAM4E,IAAWD,EAAE3E,CAAC;AACpB,uBAAW6E,KAAcD,GAAU;AAC/B,oBAAME,IAAmBF,EAASC,CAAU,KAAK;AACjD,kBAAIC;AACA,oBAAI,OAAOA,KAAqB;AAC5B,kBAAItF,EAAQsF,CAAgB,KAExBA,EAAiB,QAAQ,CAACC,GAAYC,MAAkB;AACpD,wBAAID;AACA,iCAAWE,KAAKF,GAAO;AACnB,8BAAMJ,IAAII,EAAME,CAAC;AACjB,4BAAIN,KAAKA,EAAE,SAAA,EAAW,SAAS,GAAG;AAC9B,gCAAMO,IAAI,IAAIlF,EAAE,SAAA,CAAU,KAAK6E,IAAa,IAAIG,EAAM,SAAA,CAAU,KAAKC,CAAC,EAAE,IAAI1E,EAAUoE,CAAC,CAAC;AACxF,0BAAAD,EAAE,KAAK9D,IAAIsE,CAAC;AAAA,wBAChB;AAAA,sBACJ;AAAA,kBAER,CAAC;AAAA,yBAEEJ,EAAiB,SAAA,EAAW,SAAS,GAAG;AAC/C,wBAAMI,IAAI,IAAIlF,EAAE,SAAA,CAAU,KAAK6E,CAAU,IAAItE,EAAUuE,EAAiB,SAAA,CAAU,CAAC;AACnF,kBAAAJ,EAAE,KAAK9D,IAAIsE,CAAC;AAAA,gBAChB;AAAA;AAAA,YAER;AAAA,UACJ;AAAA,QACJ;AACI,qBAAWzF,KAAOkF,GAAG;AACjB,kBAAMQ,IAASR,EAAElF,CAAG;AACpB,gBAAI0F,KAAU,QAAQA,KAAU,MAAMA,EAAO,UAAU,GAAG;AACtD,oBAAMD,IAAI,IAAIzF,CAAG,IAAIc,EAAU4E,CAAM,CAAC;AACtC,cAAAT,EAAE,KAAK9D,IAAIsE,CAAC;AAAA,YAChB;AAAA,UACJ;AAEJ;AAAA,MACJ,MAAA,CAAWP,KAAK,OAAOA,KAAM,eACzBA,IAAI;AAGR,MAAIA,KAAK,QAAQA,KAAK,MAAMA,EAAE,UAAU,KACpCD,EAAE,KAAK9D,IAAI,MAAML,EAAUoE,CAAC,CAAC;AAAA,IAErC;AACA,WAAQD,KAAKA,EAAE,KAAK,GAAG;AAAA,EAC3B;AAAA,EAEA,MAAc,KAAKhC,GAAwD;AAEvE,UAAM0C,IAAU,UAAW,MAAM,KAAK,WAAA,GAChC9E,IAAgB,CAAA;AACtB,eAAWM,KAAK8B;AACZ,MAAApC,EAAI,KAAKM,CAAC;AAEd,IAAAN,EAAI,KAAK,CAAC+E,GAAWC,MACVD,EAAE,YAAA,EAAc,cAAcC,EAAE,aAAa,CACvD;AACD,UAAMhD,IAAgB,CAAA;AACtB,IAAAhC,EAAI,QAAQ,CAACqE,MAAc;AACvB,UAAInE,IAAyBkC,EAAKiC,CAAC;AACnC,MAAI,OAAOnE,KAAU,aACjBA,IAAQ,KAAK,UAAUA,CAAK,IAEhC8B,EAAI,KAAKqC,IAAI,MAAMnE,CAAK;AAAA,IAC5B,CAAC;AACD,UAAM+E,IAAoBjD,EAAI,KAAK,GAAG,GAChCkD,IAAMC,EAAI,KAAKF,IAAYH,GAAS,mBAAmB,GACvDM,IAAU;AAAA,MACZ,QAAQH;AAAA,MACR,KAAKC;AAAA,IAAA;AAET,WAAAlG,EAAO,MAAMoG,GAAS,UAAU,GACzBF;AAAA,EACX;AAAA;AAAA,EAGQ,kBAAkB9C,GAA4BgB,GAAwC;AAC1F,UAAMxB,IAASQ,KAAQ,CAAA;AACvB,WAAAR,EAAO,YAAe,KAAK,IAAA,IAAQ,IACnCA,EAAO,UAAaxC,EAAa,EAAE,GACnCwC,EAAO,UAAa,KAAK,SACzBA,EAAO,WAAc,KAAK,UAC1BA,EAAO,QAAW,KAAK,WACvBA,EAAO,SAAY,KAAK,QACpBwB,KAAYA,EAAS,SAAS,MAC9BxB,EAAO,WAAcwB,IAElBxB;AAAA,EACX;AAAA,EAEA,MAAc,eAAe,EAAE,WAAAyD,GAAW,OAAA/B,KAAuE;AAC7G,UAAMgC,IAA4B;AAAA,MAC9B,gBAAgB;AAAA,MAChB,YAAY;AAAA,MACZ,aAAa,KAAK;AAAA,MAClB,aAAahC,GAAO,MAAM,cAAc,KAAK,SAAS,SAAA;AAAA,MACtD,aAAa,KAAK;AAAA,MAClB,WAAW,KAAK;AAAA,IAAA;AAEpB,IAAI,KAAK,QAAQ,KAAK,KAAK,SAAS,MAChCgC,EAAE,OAAU,KAAK,OAEjB,KAAK,aAAa,KAAK,UAAU,SAAS,MAC1CA,EAAE,QAAQ,IAAI,KAAK,YAEnB,KAAK,aAAa,KAAK,UAAU,SAAS,MAC1CA,EAAE,QAAQ,IAAI,KAAK,YAEnBhC,MACIA,EAAM,SAASA,EAAM,MAAM,SAAS,KAAKA,EAAM,YAAYA,EAAM,SAAS,SAAS,MACnFgC,EAAE,gBAAmBhC,EAAM,OAC3BgC,EAAE,WAAchC,EAAM,WAEtBA,EAAM,UACNgC,EAAEhC,EAAM,MAAM,UAAU,IAAIA,EAAM,MAAM;AAGhD,UAAMlB,IAAOzC,EAAe0F,CAAS,GAC/BE,IAAO,MAAM,KAAK,KAAKnD,CAAI;AACjC,WAAAkD,EAAE,OAAUC,GACLD;AAAA,EACX;AAAA,EAEA,MAAc,aAA8B;AACxC,QAAI,KAAK,YAAY,UAAU;AAC3B,aAAO,KAAK;AAEhB,UAAME,IAAM,KAAK,UAAU,KAAK,WAAW,GACrCF,IAAI;AAAA,MACN,gBAAgB;AAAA,MAChB,YAAY;AAAA,MACZ,WAAW,KAAK;AAAA,IAAA,GAEdF,IAAU;AAAA,MACZ,KAAOI;AAAA,MACP,SAAWF;AAAA,IAAA;AAEf,IAAAtG,EAAO,MAAMoG,GAAS,OAAO;AAC7B,UAAMpD,IAAM,MAAM,MAAMwD,GAAK;AAAA,MACzB,QAAQ;AAAA,MACR,SAASF;AAAA,MACT,aAAa;AAAA,MACb,OAAO;AAAA,IAAA,CACV;AACD,QAAItD,EAAI,IAAI;AACR,YAAMlC,IAAS,MAAMkC,EAAI,KAAA;AACzB,aAAAhD,EAAO,MAAMc,EAAO,MAAM,cAAc,GACjCA,EAAO;AAAA,IAClB;AACA,UAAM,IAAI,MAAM,oBAAoB;AAAA,EACxC;AAAA,EAEQ,UAAU4B,GAAqB;AACnC,WAAO,GAAG,KAAK,OAAO,IAAIA,CAAG;AAAA,EACjC;AAAA,EAEA,MAAM,OAAoC;AACtC,UAAMM,IAAM,MAAM,KAAK,IAAe;AAAA,MAClC,KAAK;AAAA,IAAA,CACR;AACD,QAAIA,EAAI,SAAS;AACb,YAAMI,IAAOJ,EAAI;AACjB,UAAII;AACA,eAAOA,EAAK,UAAa,SAAA;AAAA,IAEjC;AAAA,EAEJ;AAAA;AAAA,EAGA,MAAM,IAAO,EAAE,KAAAV,GAAK,MAAAU,GAAM,OAAAkB,GAAO,OAAAmC,IAAQ,aAAsE;AAC3G,UAAM7D,IAAS,KAAK,kBAAkBQ,CAAI,GACpCiD,IAAY,KAAK,oBAAoBzD,CAAM,GAC3CC,IAAU,MAAM,KAAK,eAAe,EAAE,WAAawD,GAAW,OAAS/B,GAAO,GAC9EkC,IAAM,GAAG,KAAK,UAAU9D,CAAG,CAAC,IAAI2D,EAAU,SAAA,CAAU,IACpDD,IAAU;AAAA,MACZ,KAAOI;AAAA,MACP,SAAW3D;AAAA,IAAA;AAEf,IAAA7C,EAAO,KAAKoG,GAAS,KAAK;AAC1B,UAAMpD,IAAM,MAAM,MAAMwD,GAAK;AAAA,MACzB,QAAU;AAAA,MACV,SAAW3D;AAAA,MACX,aAAe;AAAA,MACf,OAAS4D;AAAA,IAAA,CACZ;AACD,QAAIzD,EAAI,IAAI;AACR,YAAMC,IAAa,OAAO,YAAYD,EAAI,QAAQ,SAAS,GACrDlC,IAAS,EAAE,GAAG,MAAMkC,EAAI,KAAA,GAAQ,SAASC,EAAA;AAC/C,aAAAjD,EAAO,MAAMc,GAAQ,YAAY,GAC1BA;AAAA,IACX;AACA,UAAMoC,IAAM;AAAA,MACR,MAAMF,EAAI;AAAA,MACV,SAAS;AAAA,MACT,KAAKA,EAAI;AAAA,IAAA;AAEb,WAAAhD,EAAO,MAAMkD,CAAG,GACTA;AAAA,EACX;AAAA;AAAA,EAGA,MAAM,KAAQ,EAAE,KAAAR,GAAK,MAAAU,GAAM,OAAAkB,GAAO,OAAAmC,IAAQ,aAAsE;AAC5G,IAAArD,IAAOA,IAAO,EAAE,GAAGA,EAAA,IAAS,CAAA;AAC5B,UAAMsD,IAAStD,EAAK,UAAU,QACxBuD,IAAWvD,EAAK,YAAY;AAClC,IAAIsD,KACA,OAAOtD,EAAK,QAEZuD,KACA,OAAOvD,EAAK;AAEhB,UAAMR,IAAS,KAAK,kBAAkBQ,CAAI,GACpCiD,IAAY,KAAK,oBAAoBzD,CAAM,GAC3CC,IAAU,MAAM,KAAK,eAAe,EAAE,WAAawD,GAAW,OAAS/B,GAAO;AACpF,IAAIoC,KAAUC,MACV9D,EAAQ,cAAc,IAAI,iCAAiC8D,CAAQ;AAEvE,UAAMH,IAAM,KAAK,UAAU9D,CAAG,GACxB0D,IAAU;AAAA,MACZ,KAAOI;AAAA,MACP,SAAW3D;AAAA,MACX,QAAUD;AAAA,IAAA;AAEd,IAAA5C,EAAO,KAAKoG,GAAS,MAAM;AAC3B,UAAMQ,IAAOF,IAAS,GAAGF,CAAG,IAAIH,CAAS,KAAKG,GACxCxD,IAAM,MAAM,MAAM4D,GAAM;AAAA,MAC1B,QAAU;AAAA,MACV,SAAW/D;AAAA,MACX,MAAQ6D,KAAkBL,EAAU,SAAA;AAAA,MACpC,aAAe;AAAA,MACf,OAASI;AAAA,IAAA,CACZ;AACD,QAAIzD,EAAI,IAAI;AACR,YAAMC,IAAa,OAAO,YAAYD,EAAI,QAAQ,SAAS,GACrDlC,IAAS,EAAE,GAAG,MAAMkC,EAAI,KAAA,GAAQ,SAASC,EAAA;AAC/C,aAAAjD,EAAO,MAAMc,GAAQ,aAAa,GAC3BA;AAAA,IACX;AACA,UAAMoC,IAAM;AAAA,MACR,MAAMF,EAAI;AAAA,MACV,SAAS;AAAA,MACT,KAAKA,EAAI;AAAA,IAAA;AAEb,WAAAhD,EAAO,MAAMkD,CAAG,GACTA;AAAA,EACX;AAAA;AAAA,EAGA,MAAM,OAAO,EAAE,KAAAR,GAAK,MAAAU,GAAM,OAAAkB,KAA2E;AACjG,IAAAlB,IAAOA,IAAO,EAAE,GAAGA,EAAA,IAAS,CAAA;AAC5B,UAAMsD,IAAStD,EAAK,UAAU,QACxBuD,IAAWvD,EAAK,YAAY;AAClC,IAAIsD,KACA,OAAOtD,EAAK,QAEZuD,KACA,OAAOvD,EAAK;AAEhB,UAAMR,IAAS,KAAK,kBAAkBQ,CAAI,GACpCiD,IAAY,KAAK,oBAAoBzD,CAAM,GAE3CC,IAAU,MAAM,KAAK,eAAe,EAAE,WAAawD,GAAW,OAAS/B,GAAO;AACpF,IAAIoC,KAAUC,MACV9D,EAAQ,cAAc,IAAI,iCAAiC8D,CAAQ,KAEvE9D,EAAQ,aAAgB,cACxBA,EAAQ,mBAAmB,IAAI,MAC/BA,EAAQ,eAAe,IAAI;AAC3B,UAAM2D,IAAM,KAAK,UAAU9D,CAAG;AAC9B,QAAI;AACA,YAAMA,IAAMgE,IAAS,GAAGF,CAAG,IAAIH,CAAS,KAAKG,GACvCJ,IAAU;AAAA,QACZ,KAAOI;AAAA,QACP,SAAW3D;AAAA,QACX,QAAUD;AAAA,MAAA;AAEd,MAAA5C,EAAO,KAAKoG,GAAS,QAAQ;AAC7B,YAAMpD,IAAM,MAAM,MAAMN,GAAK;AAAA,QACzB,QAAQ;AAAA,QACR,SAAAG;AAAA,QACA,MAAM6D,KAAkBL,EAAU,SAAA;AAAA,QAClC,aAAa;AAAA,MAAA,CAChB;AAED,UAAI,CAACrD,EAAI;AACL,cAAM,IAAI,MAAM,uBAAuBA,EAAI,MAAM,EAAE;AAEvD,UAAI,CAACA,EAAI;AACL,cAAM,IAAI,MAAM,kBAAkB;AAEtC,YAAMC,IAAa,OAAO,YAAYD,EAAI,QAAQ,SAAS;AAC3D,aAAO,IAAI,SAASA,EAAI,MAAM;AAAA,QAC1B,SAASC;AAAA,MAAA,CACZ;AAAA,IACL,SAAS4D,GAAG;AACR,YAAMA;AAAA,IACV;AAAA,EACJ;AACJ;"}
1
+ {"version":3,"file":"iboot-http-client.es.js","sources":["../src/types/user.ts","../src/logger.ts","../src/utils.ts","../src/http-client.ts"],"sourcesContent":["export const ACCOUNT_TYPE_MAP = {\r\n GENERAL : 0,\r\n PHONE : 1,\r\n EMAIL : 2\r\n}\r\n\r\nexport const USER_TYPE_MAP = {\r\n TYPE_MGT : 0,\r\n TYPE_C : 1,\r\n TYPE_B : 2\r\n}\r\n\r\nexport const USER_FORM_MAP = {\r\n FROM_WEB : 1,\r\n FROM_PC : 2,\r\n FROM_WX_MINI_PRO : 3,\r\n FROM_WX_PLU : 4,\r\n FROM_WX_E : 5,\r\n FROM_APP : 6,\r\n FROM_DEVICE : 7\r\n}\r\n\r\nexport const USER_SEX_MAP = {\r\n unknown:0,\r\n male:1,\r\n female:2,\r\n}\r\n\r\nexport type ACCOUNT_TYPE = typeof ACCOUNT_TYPE_MAP[keyof typeof ACCOUNT_TYPE_MAP];\r\nexport type USER_TYPE = typeof USER_TYPE_MAP[keyof typeof USER_TYPE_MAP];\r\nexport type USER_FORM = typeof USER_FORM_MAP[keyof typeof USER_FORM_MAP];\r\nexport type USER_SEX = typeof USER_SEX_MAP[keyof typeof USER_SEX_MAP];\r\n\r\n// User interface\r\nexport interface User {\r\n id: string;\r\n name: string;\r\n userType: USER_TYPE;\r\n username?: string;\r\n nickname?: string;\r\n sex?: USER_SEX;\r\n headImg?: string;\r\n lastLoginTime?: string;\r\n tokenExpired?: string;\r\n deviceId?: string;\r\n status?: number;\r\n accountType?: number;\r\n enabled?: boolean;\r\n userFrom?: USER_FORM;\r\n needToReview?: boolean;\r\n socketOnline?: boolean;\r\n createTime?: string;\r\n mustChangePwd?: boolean;\r\n}","import pino from \"pino\";\r\nimport PinoPretty from \"pino-pretty\";\r\n// import koffi from 'koffi';\r\n\r\n// if (typeof window === 'undefined' && process.platform === 'win32') {\r\n// try {\r\n// const CP_UTF8 = 65001;\r\n// const kernel32 = koffi.load('Kernel32');\r\n// const setConsoleOutputCP = kernel32.func('SetConsoleOutputCP', 'bool', ['int']);\r\n// const setConsoleCP = kernel32.func('SetConsoleCP', 'bool', ['int']);\r\n// setConsoleOutputCP(CP_UTF8);\r\n// setConsoleCP(CP_UTF8);\r\n// } catch (e) {\r\n// console.log(e);\r\n// }\r\n// }\r\n\r\n// export const logger = pino({\r\n// name: process.env.APP_NAME ?? 'iBoot',\r\n// level: process.env.NODE_ENV !== 'production' ? 'debug' : 'info',\r\n// nestedKey: 'payload',\r\n// transport: {\r\n// target: 'pino-pretty',\r\n// options: {\r\n// colorize: true,\r\n// translateTime: 'SYS:yyyy-mm-dd HH:MM:ss',\r\n// ignore: 'pid,hostname',\r\n// messageFormat: '{msg}',\r\n// singleLine: true,\r\n// },\r\n// }\r\n// });\r\n\r\nconst stream = PinoPretty({\r\n colorize: true,\r\n destination: process.stdout,\r\n translateTime: 'SYS:yyyy-mm-dd HH:MM:ss',\r\n ignore: 'pid,hostname',\r\n messageFormat: '{msg}',\r\n singleLine: true,\r\n});\r\n\r\nexport const logger = pino({\r\n name: process.env.APP_NAME ?? 'iBoot',\r\n level: process.env.APP_ENV === 'production' ? 'info' : 'debug',\r\n nestedKey: 'payload'\r\n}, stream);","export const isArray = (obj: unknown) => {\r\n return (\r\n Array.isArray(obj) ||\r\n (typeof obj === \"object\" &&\r\n Object.prototype.toString.call(obj) === \"[object Array]\")\r\n );\r\n};\r\n\r\n/**\r\n * 生成指定长度的随机串\r\n * @param {Object} len\r\n */\r\nexport const randomString = (len: number) => {\r\n const l = len || 32;\r\n const $chars = \"ABCDEFGHJKMNPQRSTWXYZabcdefhijkmnprstwxyz2345678\";\r\n const maxPos = $chars.length;\r\n let pwd = \"\";\r\n for (let i = 0; i < l; i++) {\r\n pwd += $chars.charAt(Math.floor(Math.random() * maxPos));\r\n }\r\n return pwd;\r\n};\r\n\r\nexport const urlParamToJson = (urlQueryParams: string, exclude?: string[]): Record<string, string> => {\r\n const result: Record<string, string> = {};\r\n const strs = urlQueryParams.split(\"&\");\r\n strs.forEach((item) => {\r\n const arr = item.split(\"=\");\r\n if (arr[1]) {\r\n if (!exclude || exclude.indexOf(arr[0]) == -1) {\r\n result[arr[0]] = arr[1];\r\n }\r\n }\r\n });\r\n return result;\r\n};\r\n\r\nexport const urlEncode = (value: string | null | undefined): string => {\r\n if (!value || value == \"\" || value.length == 0) {\r\n return \"\";\r\n }\r\n return (\r\n encodeURIComponent(value)\r\n // .replace(/%20/g, '+')\r\n // .replace(/%2B/g, '\\\\+')\r\n .replace(/\\(/g, \"%28\")\r\n .replace(/\\)/g, \"%29\")\r\n .replace(/\\'/g, \"%27\")\r\n .replace(/\\!/g, \"%21\")\r\n .replace(/\\~/g, \"%7E\")\r\n );\r\n};\r\n\r\nexport const dateFormat = (dt: Date, fmt: string) => {\r\n const o:Record<string, number> = {\r\n \"M+\": dt.getMonth() + 1, //月份\r\n \"d+\": dt.getDate(), //日\r\n \"h+\": dt.getHours(), //小时\r\n \"m+\": dt.getMinutes(), //分\r\n \"s+\": dt.getSeconds(), //秒\r\n \"q+\": Math.floor((dt.getMonth() + 3) / 3), //季度\r\n S: dt.getMilliseconds(), //毫秒\r\n };\r\n if (/(y+)/.test(fmt)){\r\n const regx = new RegExp(/(y+)/);\r\n const value = regx.exec(fmt);\r\n let len = 0;\r\n if(value && value.length > 0){\r\n len = value[0].length;\r\n }\r\n fmt = fmt.replace(/(y+)/, dt.getFullYear() + \"\").substring(4 - len);\r\n }\r\n\r\n for (const k in o){\r\n const s:string = \"(\" + k + \")\";\r\n const regx = new RegExp(s);\r\n if(regx.test(fmt)){\r\n const value = regx.exec(fmt);\r\n let len = 0;\r\n if(value && value.length > 0){\r\n len = value[0].length;\r\n }\r\n fmt = fmt.replace(regx, len == 1 ? o[k].toString() : (\"00\" + o[k]).substring(o[k].toString().length))\r\n }\r\n }\r\n return fmt;\r\n}","import md5 from \"js-md5\";\r\nimport CryptoJS from 'crypto-js';\r\nimport { isArray, randomString, urlEncode, urlParamToJson } from \"./utils\";\r\nimport {\r\n ClientGetParams,\r\n ClientPostParams,\r\n CSRFToken,\r\n CurWebsite,\r\n HttpClientOpts,\r\n HttpHeaders,\r\n HttpToken,\r\n ResultModel,\r\n ServerRequestOptions,\r\n ICookies,\r\n IStorage\r\n} from \"./types/http\";\r\nimport { User, USER_TYPE, USER_TYPE_MAP } from \"./types/user\";\r\nimport { logger } from \"./logger\";\r\n\r\n\r\nexport const DEFAULT_LOCALE = 'zh-CN';\r\nexport const DEVICE_ID_KEY = \"_device_id_key\";\r\nexport const CURRENT_WEBSITE_KEY = \"_current_website_key\"\r\n\r\nconst _GET_ERROR = \"Get request error!\"\r\nconst _POST_ERROR = \"Post request error!\";\r\n\r\nexport const COOKIE_NAMES = {\r\n \"IBOOT_DEVICE_ID\": \"dvid\",\r\n \"IBOOT_LANG\": \"lang\",\r\n \"IBOOT_WEBSITE_ID\": \"wid\",\r\n \"IBOOT_WEBSITE_NO\": \"wno\",\r\n \"IBOOT_TOKEN\": \"token\",\r\n \"IBOOT_USER\": \"user\"\r\n}\r\n\r\nexport const HEADER_NAMES = {\r\n \"DEVICE_ID\": \"Device-Id\",\r\n \"LANG\": \"Lang\",\r\n \"WEBSITE_ID\": \"Website-Id\",\r\n \"WEBSITE_NO\": \"Website-No\",\r\n}\r\n\r\n\r\nconst getDefaultRequestHeader = (storage: Readonly<IStorage>): HttpHeaders => {\r\n if (!storage.get) {\r\n throw new Error(\"The get method of IStorage has not been implemented.\")\r\n }\r\n const devideId = storage.get(DEVICE_ID_KEY) ?? ''\r\n const json = storage.get(CURRENT_WEBSITE_KEY);\r\n const curWebsite: CurWebsite | null = json != null ? JSON.parse(json) : null;\r\n const header: HttpHeaders = {}\r\n if (devideId.length > 0) {\r\n header['Device-Id'] = devideId\r\n }\r\n if (curWebsite) {\r\n header['Lang'] = curWebsite.language;\r\n if (curWebsite.websiteId) {\r\n header['Website-Id'] = curWebsite.websiteId;\r\n }\r\n if (curWebsite.websiteNo) {\r\n header['Website-No'] = curWebsite.websiteNo\r\n }\r\n }\r\n return header;\r\n};\r\n\r\n\r\nexport const setDefaultRequestHeader = ({ deviceId, website }: Readonly<{ deviceId: string, website?: CurWebsite }>, storage: IStorage): void => {\r\n if (!storage.set) {\r\n throw new Error(\"The set method of IStorage has not been implemented.\")\r\n }\r\n storage.set(DEVICE_ID_KEY, deviceId);\r\n if (website) {\r\n storage.set(CURRENT_WEBSITE_KEY, JSON.stringify(website));\r\n }\r\n}\r\n\r\nexport const get = async <T>(url: string, opts?: ClientGetParams): Promise<ResultModel<T>> => {\r\n if (opts?.data) {\r\n const params = new URLSearchParams(opts.data);\r\n if (url.indexOf(\"?\") != -1) {\r\n url += `&${params}`\r\n } else {\r\n url += `?${params}`\r\n }\r\n }\r\n const headers: Record<string, string> = (opts && opts.storage && opts.storage.get) ? getDefaultRequestHeader(opts.storage) : {}\r\n const heads = opts?.headers;\r\n if (heads) {\r\n for (const field in heads) {\r\n const value = heads[field];\r\n if (value) {\r\n headers[field] = value;\r\n }\r\n }\r\n }\r\n logger.info({\r\n \"url\": url,\r\n \"headers\": headers,\r\n }, \"GET\")\r\n const res = await fetch(url, {\r\n method: 'GET',\r\n headers: headers,\r\n cache: opts?.useCache ? 'force-cache' : 'default'\r\n });\r\n\r\n if (res.ok) {\r\n const headersMap = Object.fromEntries(res.headers.entries());\r\n const result = { ...await res.json(), headers: headersMap };\r\n logger.debug(result, \"GET_RESULT\")\r\n return result\r\n }\r\n const msg = {\r\n code: res.status,\r\n success: false,\r\n msg: res.statusText\r\n }\r\n logger.error(msg);\r\n return msg;\r\n}\r\n\r\nexport const post = async <T>(url: string, opts?: ClientPostParams): Promise<ResultModel<T>> => {\r\n const data = opts?.data ?? {};\r\n const heads = opts?.headers;\r\n let body: string | FormData;\r\n const defaultHeads = (opts && opts.storage && opts.storage.get) ? getDefaultRequestHeader(opts.storage) : {}\r\n const proxyHeaders = new Headers(defaultHeads);\r\n if (!(data instanceof FormData)) {\r\n body = JSON.stringify(data);\r\n proxyHeaders.set('Content-Type', 'application/json');\r\n } else {\r\n body = data;\r\n }\r\n if (heads) {\r\n for (let field in heads) {\r\n const value = heads[field];\r\n if (value) {\r\n proxyHeaders.set(field, value);\r\n }\r\n }\r\n }\r\n logger.info({\r\n \"url\": url,\r\n \"headers\": proxyHeaders,\r\n }, \"POST\")\r\n const res = await fetch(url, {\r\n method: 'POST',\r\n headers: proxyHeaders,\r\n body: body,\r\n });\r\n if (res.ok) {\r\n const headersMap = Object.fromEntries(res.headers.entries());\r\n const result = { ...await res.json(), headers: headersMap };\r\n logger.debug(result, \"POST_RESULT\")\r\n return result\r\n }\r\n const msg = {\r\n code: res.status,\r\n success: false,\r\n msg: res.statusText,\r\n }\r\n logger.error(msg);\r\n return msg;\r\n}\r\n\r\nexport const iGet = async <T>(url: string, opts?: ClientGetParams): Promise<T | undefined> => {\r\n const res = await get<T>(url, opts);\r\n if (res.success) {\r\n return res.data as T;\r\n }\r\n if (opts?.showError) {\r\n opts.showError(res.msg ?? _GET_ERROR);\r\n return;\r\n }\r\n throw Error(res.msg ?? _GET_ERROR)\r\n}\r\n\r\nexport const iPost = async <T>(url: string, opts?: ClientPostParams): Promise<T | undefined> => {\r\n const res = await post<T>(url, opts);\r\n if (res.success) {\r\n return res.data;\r\n }\r\n if (opts?.showError) {\r\n opts.showError(res.msg ?? _POST_ERROR);\r\n return;\r\n }\r\n throw Error(res.msg ?? _POST_ERROR)\r\n}\r\n\r\nexport const iPostSuccess = async (url: string, opts?: ClientPostParams): Promise<boolean> => {\r\n const res = await post(url, opts);\r\n if (res.success) {\r\n if (opts?.showSuccess) {\r\n opts.showSuccess(res.msg ?? 'SUCCESS')\r\n }\r\n return true;\r\n }\r\n if (opts?.showError) {\r\n opts.showError(res.msg ?? _POST_ERROR);\r\n }\r\n return false;\r\n}\r\n\r\nexport const getHttpOpts = (storage: IStorage): HttpClientOpts => {\r\n if (storage.get) {\r\n const deviceId = storage.get(HEADER_NAMES.DEVICE_ID);\r\n const lang = storage.get(HEADER_NAMES.LANG);\r\n const websiteId = storage.get(HEADER_NAMES.WEBSITE_ID);\r\n const websiteNo = storage.get(HEADER_NAMES.WEBSITE_NO);\r\n const result: HttpClientOpts = {}\r\n if (deviceId && deviceId.length > 0) {\r\n result.deviceId = deviceId;\r\n }\r\n if (lang && lang.length > 0) {\r\n result.lang = lang\r\n }\r\n if (websiteId && websiteId.length > 0) {\r\n result.websiteId = websiteId\r\n }\r\n if (websiteNo && websiteNo.length > 0) {\r\n result.websiteNo = websiteNo\r\n }\r\n return result;\r\n }\r\n throw new Error(\"The set method of IStorage has not been implemented.\")\r\n}\r\n\r\nexport const getLoginUser = (cookies: ICookies): User | undefined => {\r\n if (cookies.get) {\r\n const userjson = cookies.get(COOKIE_NAMES.IBOOT_USER)\r\n if (userjson && userjson.length > 0) {\r\n return JSON.parse(userjson);\r\n }\r\n }\r\n return undefined\r\n}\r\n\r\nexport const getToken = (cookies: ICookies): HttpToken | undefined => {\r\n if (cookies.get) {\r\n const userjson = cookies.get(COOKIE_NAMES.IBOOT_USER);\r\n if (userjson && userjson.length > 0) {\r\n const user = JSON.parse(userjson);\r\n const username = user.username;\r\n const utype = user.userType.toString();\r\n const token = cookies.get(COOKIE_NAMES.IBOOT_TOKEN);\r\n if (token) {\r\n return {\r\n \"username\": username,\r\n \"utype\": utype,\r\n \"token\": token\r\n }\r\n }\r\n }\r\n }\r\n return undefined\r\n}\r\n\r\nexport const setToken = (data: User & { token: string }, cookies: ICookies): void => {\r\n const { id, name, username, nickname, headImg, token, lastLoginTime, deviceId, userType, mustChangePwd } = data;\r\n const loginUser: User = {\r\n id: id,\r\n name: name,\r\n username: username,\r\n nickname: nickname || name,\r\n headImg: headImg,\r\n lastLoginTime: lastLoginTime,\r\n deviceId: deviceId,\r\n userType: userType,\r\n accountType: 0,\r\n needToReview: false,\r\n socketOnline: false,\r\n mustChangePwd: mustChangePwd\r\n };\r\n if (!cookies.set) {\r\n throw new Error('cookies set function is undefined')\r\n }\r\n cookies.set(COOKIE_NAMES.IBOOT_TOKEN, token, {\r\n path: '/',\r\n secure: process.env.APP_ENV === 'production',\r\n httpOnly: true,\r\n sameSite: 'strict'\r\n });\r\n cookies.set(COOKIE_NAMES.IBOOT_USER, JSON.stringify(loginUser))\r\n}\r\n\r\nexport const cleanToken = (cookies: ICookies): void => {\r\n if (!cookies.set) {\r\n throw new Error('cookies set function is undefined')\r\n }\r\n cookies.set(COOKIE_NAMES.IBOOT_TOKEN, '', {\r\n maxAge: -1, //设置为 -1表示立即过期\r\n httpOnly: true,\r\n path: '/',\r\n });\r\n cookies.set(COOKIE_NAMES.IBOOT_USER, '', {\r\n maxAge: -1, //设置为 -1表示立即过期\r\n httpOnly: true,\r\n path: '/',\r\n });\r\n if (!cookies.delete) {\r\n throw new Error('cookies delete function is undefined')\r\n }\r\n cookies.delete(COOKIE_NAMES.IBOOT_TOKEN);\r\n cookies.delete(COOKIE_NAMES.IBOOT_USER);\r\n}\r\n\r\nexport class HttpClient {\r\n private readonly baseUrl: string;\r\n private readonly helloMethod: string;\r\n private readonly apiKey: string;\r\n private readonly userType: USER_TYPE;\r\n private readonly userFrom: string;\r\n private readonly deviceId: string;\r\n private readonly version: string = '1';\r\n private readonly lang: string;\r\n private readonly websiteId?: string;\r\n private readonly websiteNo?: string;\r\n constructor(opts: Readonly<HttpClientOpts>) {\r\n const isProduction = process.env.APP_ENV === 'production';\r\n if (!isProduction) {\r\n logger.warn(\"This is currently a development environment!\")\r\n }\r\n this.baseUrl = process.env.APP_BASEURL!;\r\n this.apiKey = process.env.APP_APIKEY!;\r\n this.userFrom = process.env.APP_USERFROM ?? '1';\r\n\r\n this.helloMethod = opts.helloURL ?? ''\r\n this.userType = opts.userType ?? USER_TYPE_MAP.TYPE_MGT;\r\n this.deviceId = opts.deviceId ?? randomString(10);\r\n this.lang = opts.lang ?? DEFAULT_LOCALE;\r\n this.websiteId = opts.websiteId\r\n this.websiteNo = opts.websiteNo\r\n }\r\n\r\n encrypt(data: string) {\r\n const key = CryptoJS.enc.Utf8.parse(this.apiKey);\r\n return CryptoJS.AES.encrypt(data, key).toString();\r\n }\r\n\r\n decrypt(data: string) {\r\n const key = CryptoJS.enc.Utf8.parse(this.apiKey);\r\n return CryptoJS.AES.decrypt(data, key, {\r\n mode: CryptoJS.mode.ECB,\r\n }).toString(CryptoJS.enc.Utf8);\r\n }\r\n\r\n //eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n private convertUrlParameter(data: Record<string, any>): string {\r\n const p: string[] = [];\r\n for (const o in data) {\r\n let v = data[o];\r\n if (v && typeof v === \"string\") {\r\n v = v.trim();\r\n } else if (v && typeof v === \"object\") {\r\n if (isArray(v)) {\r\n if (v.length === 0) {\r\n continue;\r\n }\r\n for (let i = 0; i < v.length; i++) {\r\n const arr_item = v[i];\r\n for (const item_field in arr_item) {\r\n const item_field_value = arr_item[item_field] ?? undefined;\r\n if (item_field_value) {\r\n if (typeof item_field_value === \"object\") {\r\n if (isArray(item_field_value)) {\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n item_field_value.forEach((item1: any, index: number) => {\r\n if (item1) {\r\n for (const f in item1) {\r\n const v = item1[f];\r\n if (v && v.toString().length > 0) {\r\n const s = `[${i.toString()}].${item_field + `[${index.toString()}].${f}`}=${urlEncode(v)}`;\r\n p.push(o + s);\r\n }\r\n }\r\n }\r\n });\r\n }\r\n } else if (item_field_value.toString().length > 0) {\r\n const s = `[${i.toString()}].${item_field}=${urlEncode(item_field_value.toString())}`;\r\n p.push(o + s);\r\n }\r\n }\r\n }\r\n }\r\n } else {\r\n for (const obj in v) {\r\n const oValue = v[obj];\r\n if (oValue != null && oValue != \"\" && oValue.length != 0) {\r\n const s = `.${obj}=${urlEncode(oValue)}`;\r\n p.push(o + s);\r\n }\r\n }\r\n }\r\n continue;\r\n } else if (v && typeof v === \"function\") {\r\n v = null;\r\n }\r\n\r\n if (v != null && v != \"\" && v.length != 0) {\r\n p.push(o + \"=\" + urlEncode(v));\r\n }\r\n }\r\n return (p && p.join(\"&\"));\r\n }\r\n\r\n private async sign(data: Record<string, object | string>): Promise<string> {\r\n //由后台分配\r\n const _apiKey = \"&key=\" + (await this.helloIboot());\r\n const arr: string[] = [];\r\n for (const o in data) {\r\n arr.push(o);\r\n }\r\n arr.sort((a: string, b: string) => {\r\n return a.toLowerCase().localeCompare(b.toLowerCase());\r\n });\r\n const res: string[] = [];\r\n arr.forEach((v: string) => {\r\n let value: object | string = data[v];\r\n if (typeof value === \"object\") {\r\n value = JSON.stringify(value);\r\n }\r\n res.push(v + \"=\" + value);\r\n });\r\n const paramsStr: string = res.join(\"&\");\r\n const str = md5.md5((paramsStr + _apiKey).toLocaleUpperCase());\r\n const logInfo = {\r\n params: paramsStr,\r\n md5: str\r\n }\r\n logger.debug(logInfo, \"API_SIGN\")\r\n return str;\r\n }\r\n\r\n //eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n private assemblyParameter(data?: Record<string, any>, username?: string): Record<string, any> {\r\n const params = data ?? {};\r\n params['timestamp'] = Date.now() + '';\r\n params['echostr'] = randomString(10);\r\n params['version'] = this.version;\r\n params['deviceId'] = this.deviceId;\r\n params['webid'] = this.websiteId;\r\n params['apiKey'] = this.apiKey;\r\n if (username && username.length > 0) {\r\n params['username'] = username;\r\n }\r\n return params;\r\n }\r\n\r\n private async assemblyHeader({ urlParams, token }: Readonly<{ urlParams: string, token?: Readonly<HttpToken> }>) {\r\n const h: Record<string, string> = {\r\n 'Content-Type': 'application/x-www-form-urlencoded',\r\n 'Res-Type': 'json',\r\n 'Device-Id': this.deviceId,\r\n 'User-Type': token?.utype.toString() ?? this.userType.toString(),\r\n 'User-From': this.userFrom,\r\n 'Api-Key': this.apiKey\r\n }\r\n if (this.lang && this.lang.length > 0) {\r\n h['Lang'] = this.lang\r\n }\r\n if (this.websiteId && this.websiteId.length > 0) {\r\n h['Web-Id'] = this.websiteId\r\n }\r\n if (this.websiteNo && this.websiteNo.length > 0) {\r\n h['Web-No'] = this.websiteNo\r\n }\r\n if (token) {\r\n if (token.token && token.token.length > 0 && token.username && token.username.length > 0) {\r\n h['Authorization'] = token.token;\r\n h['Username'] = token.username;\r\n }\r\n if (token.xcsrf) {\r\n h[token.xcsrf.csrfHeader] = token.xcsrf.csrfToken;\r\n }\r\n }\r\n const data = urlParamToJson(urlParams);\r\n const sign = await this.sign(data);\r\n h['Sign'] = sign\r\n return h;\r\n }\r\n\r\n private async helloIboot(): Promise<string> {\r\n if (this.helloMethod.length <= 0) {\r\n return this.apiKey;\r\n }\r\n const api = this.getApiUrl(this.helloMethod);\r\n const h = {\r\n 'Content-Type': 'application/x-www-form-urlencoded',\r\n 'Res-Type': 'json',\r\n 'Api-Key': this.apiKey\r\n }\r\n const logInfo = {\r\n \"url\": api,\r\n \"headers\": h\r\n }\r\n logger.debug(logInfo, \"HELLO\");\r\n const res = await fetch(api, {\r\n method: 'GET',\r\n headers: h,\r\n credentials: 'include',\r\n cache: 'force-cache'\r\n });\r\n if (res.ok) {\r\n const result = await res.json();\r\n logger.debug(result.data, 'HELLO RESULT')\r\n return result.data;\r\n }\r\n throw new Error('hello iBoot error!')\r\n }\r\n\r\n private getApiUrl(url: string): string {\r\n return `${this.baseUrl}/${url}`;\r\n }\r\n\r\n async csrf(): Promise<string | undefined> {\r\n const res = await this.get<CSRFToken>({\r\n url: 'guest/csrf'\r\n });\r\n if (res.success) {\r\n const data = res.data;\r\n if (data) {\r\n return data[\"csrfToken\"].toString();\r\n }\r\n }\r\n return undefined;\r\n }\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n async get<T>({ url, data, token, cache = 'default' }: Readonly<ServerRequestOptions>): Promise<ResultModel<T>> {\r\n const params = this.assemblyParameter(data);\r\n const urlParams = this.convertUrlParameter(params);\r\n const headers = await this.assemblyHeader({ \"urlParams\": urlParams, \"token\": token });\r\n const api = `${this.getApiUrl(url)}?${urlParams.toString()}`\r\n const logInfo = {\r\n \"url\": api,\r\n \"headers\": headers\r\n }\r\n logger.info(logInfo, \"GET\");\r\n const res = await fetch(api, {\r\n \"method\": 'GET',\r\n \"headers\": headers,\r\n \"credentials\": 'include',\r\n \"cache\": cache\r\n });\r\n if (res.ok) {\r\n const headersMap = Object.fromEntries(res.headers.entries());\r\n const result = { ...await res.json(), headers: headersMap };\r\n logger.debug(result, \"GET_RESULT\")\r\n return result;\r\n }\r\n const msg = {\r\n code: res.status,\r\n success: false,\r\n msg: res.statusText\r\n }\r\n logger.error(msg);\r\n return msg;\r\n }\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n async post<T>({ url, data, token, cache = \"default\" }: Readonly<ServerRequestOptions>): Promise<ResultModel<T>> {\r\n data = data ? { ...data } : {}\r\n const buffer = data.buffer ?? undefined;\r\n const boundary = data.boundary ?? undefined;\r\n if (buffer) {\r\n delete data.buffer;\r\n }\r\n if (boundary) {\r\n delete data.boundary;\r\n }\r\n const params = this.assemblyParameter(data);\r\n const urlParams = this.convertUrlParameter(params);\r\n const headers = await this.assemblyHeader({ \"urlParams\": urlParams, \"token\": token });\r\n if (buffer && boundary) {\r\n headers['Content-Type'] = `multipart/form-data; boundary=${boundary}`;\r\n }\r\n const api = this.getApiUrl(url);\r\n const logInfo = {\r\n \"url\": api,\r\n \"headers\": headers,\r\n \"params\": params\r\n }\r\n logger.info(logInfo, \"POST\");\r\n const urls = buffer ? `${api}?${urlParams}` : api;\r\n const res = await fetch(urls, {\r\n \"method\": 'POST',\r\n \"headers\": headers,\r\n \"body\": buffer ? buffer : urlParams.toString(),\r\n \"credentials\": 'include',\r\n \"cache\": cache\r\n });\r\n if (res.ok) {\r\n const headersMap = Object.fromEntries(res.headers.entries());\r\n const result = { ...await res.json(), headers: headersMap };\r\n logger.debug(result, \"POST_RESULT\");\r\n return result;\r\n }\r\n const msg = {\r\n code: res.status,\r\n success: false,\r\n msg: res.statusText\r\n }\r\n logger.error(msg);\r\n return msg;\r\n }\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n async stream({ url, data, token }: Readonly<Omit<ServerRequestOptions, 'cache'>>): Promise<Response> {\r\n data = data ? { ...data } : {}\r\n const buffer = data.buffer ?? undefined;\r\n const boundary = data.boundary ?? undefined;\r\n if (buffer) {\r\n delete data.buffer;\r\n }\r\n if (boundary) {\r\n delete data.boundary;\r\n }\r\n const params = this.assemblyParameter(data);\r\n const urlParams = this.convertUrlParameter(params); //new URLSearchParams(params);\r\n\r\n const headers = await this.assemblyHeader({ \"urlParams\": urlParams, \"token\": token });\r\n if (buffer && boundary) {\r\n headers['Content-Type'] = `multipart/form-data; boundary=${boundary}`;\r\n }\r\n headers['Connection'] = 'keep-alive';\r\n headers['X-Accel-Buffering'] = 'no'; //防止 Nginx 缓存\r\n headers['Cache-Control'] = 'no-cache';\r\n const api = this.getApiUrl(url)\r\n try {\r\n const url = buffer ? `${api}?${urlParams}` : api;\r\n const logInfo = {\r\n \"url\": api,\r\n \"headers\": headers,\r\n \"params\": params\r\n }\r\n logger.info(logInfo, \"STREAM\");\r\n const res = await fetch(url, {\r\n method: 'POST',\r\n headers: headers,\r\n body: buffer ? buffer : urlParams.toString(),\r\n credentials: 'include'\r\n });\r\n\r\n if (!res.ok) {\r\n throw new Error(`HTTP error! status: ${res.status}`);\r\n }\r\n if (!res.body) {\r\n throw new Error('No response body');\r\n }\r\n const headersMap = Object.fromEntries(res.headers.entries());\r\n return new Response(res.body, {\r\n headers: headersMap\r\n });\r\n } catch (e) {\r\n throw e;\r\n }\r\n }\r\n}"],"names":["ACCOUNT_TYPE_MAP","USER_TYPE_MAP","USER_FORM_MAP","USER_SEX_MAP","stream","PinoPretty","logger","pino","isArray","obj","randomString","len","l","$chars","maxPos","pwd","i","urlParamToJson","urlQueryParams","exclude","result","item","arr","urlEncode","value","dateFormat","dt","fmt","o","k","regx","DEFAULT_LOCALE","DEVICE_ID_KEY","CURRENT_WEBSITE_KEY","_GET_ERROR","_POST_ERROR","COOKIE_NAMES","HEADER_NAMES","getDefaultRequestHeader","storage","devideId","json","curWebsite","header","setDefaultRequestHeader","deviceId","website","get","url","opts","params","headers","heads","field","res","headersMap","msg","post","data","body","defaultHeads","proxyHeaders","iGet","iPost","iPostSuccess","getHttpOpts","lang","websiteId","websiteNo","getLoginUser","cookies","userjson","getToken","user","username","utype","token","setToken","id","name","nickname","headImg","lastLoginTime","userType","mustChangePwd","loginUser","cleanToken","HttpClient","key","CryptoJS","p","v","arr_item","item_field","item_field_value","item1","index","f","s","oValue","_apiKey","a","b","paramsStr","str","md5","logInfo","urlParams","h","sign","api","cache","buffer","boundary","urls","e"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- (function(a,T){typeof exports=="object"&&typeof module<"u"?T(exports,require("pino"),require("pino-pretty"),require("js-md5"),require("crypto-js")):typeof define=="function"&&define.amd?define(["exports","pino","pino-pretty","js-md5","crypto-js"],T):(a=typeof globalThis<"u"?globalThis:a||self,T(a["iboot-http-client"]={},a.pino,a.PinoPretty,a.md5,a.CryptoJS))})(this,(function(a,T,B,j,y){"use strict";const D={GENERAL:0,PHONE:1,EMAIL:2},A={TYPE_MGT:0,TYPE_C:1,TYPE_B:2},K={FROM_WEB:1,FROM_PC:2,FROM_WX_MINI_PRO:3,FROM_WX_PLU:4,FROM_WX_E:5,FROM_APP:6,FROM_DEVICE:7},H={unknown:0,male:1,female:2},$=B({colorize:!0,destination:process.stdout,translateTime:"SYS:yyyy-mm-dd HH:MM:ss",ignore:"pid,hostname",messageFormat:"{msg}",singleLine:!0}),h=T({name:process.env.APP_NAME??"iBoot",level:process.env.APP_ENV==="production"?"info":"debug",nestedKey:"payload"},$),w=r=>Array.isArray(r)||typeof r=="object"&&Object.prototype.toString.call(r)==="[object Array]",O=r=>{const t=r||32,e="ABCDEFGHJKMNPQRSTWXYZabcdefhijkmnprstwxyz2345678",n=e.length;let s="";for(let o=0;o<t;o++)s+=e.charAt(Math.floor(Math.random()*n));return s},R=(r,t)=>{const e={};return r.split("&").forEach(s=>{const o=s.split("=");o[1]&&(!t||t.indexOf(o[0])==-1)&&(e[o[0]]=o[1])}),e},p=r=>!r||r==""||r.length==0?"":encodeURIComponent(r).replace(/\(/g,"%28").replace(/\)/g,"%29").replace(/\'/g,"%27").replace(/\!/g,"%21").replace(/\~/g,"%7E"),F=(r,t)=>{const e={"M+":r.getMonth()+1,"d+":r.getDate(),"h+":r.getHours(),"m+":r.getMinutes(),"s+":r.getSeconds(),"q+":Math.floor((r.getMonth()+3)/3),S:r.getMilliseconds()};if(/(y+)/.test(t)){const s=new RegExp(/(y+)/).exec(t);let o=0;s&&s.length>0&&(o=s[0].length),t=t.replace(/(y+)/,r.getFullYear()+"").substring(4-o)}for(const n in e){const s="("+n+")",o=new RegExp(s);if(o.test(t)){const i=o.exec(t);let c=0;i&&i.length>0&&(c=i[0].length),t=t.replace(o,c==1?e[n].toString():("00"+e[n]).substring(e[n].toString().length))}}return t},U="zh-CN",S="_device_id_key",b="_current_website_key",N="Get request error!",I="Post request error!",m={IBOOT_DEVICE_ID:"dvid",IBOOT_LANG:"lang",IBOOT_WEBSITE_ID:"wid",IBOOT_WEBSITE_NO:"wno",IBOOT_TOKEN:"token",IBOOT_USER:"user"},_={DEVICE_ID:"Device-Id",LANG:"Lang",WEBSITE_ID:"Website-Id",WEBSITE_NO:"Website-No"},M=r=>{if(!r.get)throw new Error("The get method of IStorage has not been implemented.");const t=r.get(S)??"",e=r.get(b),n=e!=null?JSON.parse(e):null,s={};return t.length>0&&(s["Device-Id"]=t),n&&(s.Lang=n.language,n.websiteId&&(s["Website-Id"]=n.websiteId),n.websiteNo&&(s["Website-No"]=n.websiteNo)),s},W=({deviceId:r,website:t},e)=>{if(!e.set)throw new Error("The set method of IStorage has not been implemented.");e.set(S,r),t&&e.set(b,JSON.stringify(t))},v=async(r,t)=>{if(t?.data){const i=new URLSearchParams(t.data);r.indexOf("?")!=-1?r+=`&${i}`:r+=`?${i}`}const e=t&&t.storage&&t.storage.get?M(t.storage):{},n=t?.headers;if(n)for(const i in n){const c=n[i];c&&(e[i]=c)}h.info({url:r,headers:e},"GET");const s=await fetch(r,{method:"GET",headers:e,cache:t?.useCache?"force-cache":"default"});if(s.ok){const i=Object.fromEntries(s.headers.entries()),c={...await s.json(),headers:i};return h.debug(c,"GET_RESULT"),c}const o={code:s.status,success:!1,msg:s.statusText};return h.error(o),o},P=async(r,t)=>{const e=t?.data??{},n=t?.headers;let s;const o=t&&t.storage&&t.storage.get?M(t.storage):{},i=new Headers(o);if(e instanceof FormData?s=e:(s=JSON.stringify(e),i.set("Content-Type","application/json")),n)for(let d in n){const u=n[d];u&&i.set(d,u)}h.info({url:r,headers:i},"POST");const c=await fetch(r,{method:"POST",headers:i,body:s});if(c.ok){const d=Object.fromEntries(c.headers.entries()),u={...await c.json(),headers:d};return h.debug(u,"POST_RESULT"),u}const l={code:c.status,success:!1,msg:c.statusText};return h.error(l),l},k=async(r,t)=>{const e=await v(r,t);if(e.success)return e.data;if(t?.showError){t.showError(e.msg??N);return}throw Error(e.msg??N)},G=async(r,t)=>{const e=await P(r,t);if(e.success)return e.data;if(t?.showError){t.showError(e.msg??I);return}throw Error(e.msg??I)},Y=async(r,t)=>{const e=await P(r,t);return e.success?(t?.showSuccess&&t.showSuccess(e.msg??"SUCCESS"),!0):(t?.showError&&t.showError(e.msg??I),!1)},q=r=>{if(r.get){const t=r.get(_.DEVICE_ID),e=r.get(_.LANG),n=r.get(_.WEBSITE_ID),s=r.get(_.WEBSITE_NO),o={};return t&&t.length>0&&(o.deviceId=t),e&&e.length>0&&(o.lang=e),n&&n.length>0&&(o.websiteId=n),s&&s.length>0&&(o.websiteNo=s),o}throw new Error("The set method of IStorage has not been implemented.")},V=r=>{if(r.get){const t=r.get(m.IBOOT_USER);if(t&&t.length>0)return JSON.parse(t)}},X=r=>{if(r.get){const t=r.get(m.IBOOT_USER);if(t&&t.length>0){const e=JSON.parse(t),n=e.username,s=e.userType.toString(),o=r.get(m.IBOOT_TOKEN);if(o)return{username:n,utype:s,token:o}}}},J=(r,t)=>{const{id:e,name:n,username:s,nickname:o,headImg:i,token:c,lastLoginTime:l,deviceId:d,userType:u,mustChangePwd:E}=r,f={id:e,name:n,username:s,nickname:o||n,headImg:i,lastLoginTime:l,deviceId:d,userType:u,accountType:0,needToReview:!1,socketOnline:!1,mustChangePwd:E};if(!t.set)throw new Error("cookies set function is undefined");t.set(m.IBOOT_TOKEN,c,{path:"/",secure:process.env.APP_ENV==="production",httpOnly:!0,sameSite:"strict"}),t.set(m.IBOOT_USER,JSON.stringify(f))},z=r=>{if(!r.set)throw new Error("cookies set function is undefined");if(r.set(m.IBOOT_TOKEN,"",{maxAge:-1,httpOnly:!0,path:"/"}),r.set(m.IBOOT_USER,"",{maxAge:-1,httpOnly:!0,path:"/"}),!r.delete)throw new Error("cookies delete function is undefined");r.delete(m.IBOOT_TOKEN),r.delete(m.IBOOT_USER)};class Q{baseUrl;helloMethod;apiKey;userType;userFrom;deviceId;version="1";lang;websiteId;websiteNo;constructor(t){process.env.APP_ENV==="production"||h.warn("This is currently a development environment!"),this.baseUrl=process.env.APP_BASEURL,this.apiKey=process.env.APP_APIKEY,this.userFrom=process.env.APP_USERFROM??"1",this.helloMethod=t.helloURL??"",this.userType=t.userType??A.TYPE_MGT,this.deviceId=t.deviceId??O(10),this.lang=t.lang??U,this.websiteId=t.websiteId,this.websiteNo=t.websiteNo}encrypt(t){const e=y.enc.Utf8.parse(this.apiKey);return y.AES.encrypt(t,e).toString()}decrypt(t){const e=y.enc.Utf8.parse(this.apiKey);return y.AES.decrypt(t,e,{mode:y.mode.ECB}).toString(y.enc.Utf8)}convertUrlParameter(t){const e=[];for(const n in t){let s=t[n];if(s&&typeof s=="string")s=s.trim();else if(s&&typeof s=="object"){if(w(s)){if(s.length===0)continue;for(let o=0;o<s.length;o++){const i=s[o];for(const c in i){const l=i[c]??void 0;if(l){if(typeof l=="object")w(l)&&l.forEach((d,u)=>{if(d)for(const E in d){const f=d[E];if(f&&f.toString().length>0){const g=`[${o.toString()}].${c+`[${u.toString()}].${E}`}=${p(f)}`;e.push(n+g)}}});else if(l.toString().length>0){const d=`[${o.toString()}].${c}=${p(l.toString())}`;e.push(n+d)}}}}}else for(const o in s){const i=s[o];if(i!=null&&i!=""&&i.length!=0){const c=`.${o}=${p(i)}`;e.push(n+c)}}continue}else s&&typeof s=="function"&&(s=null);s!=null&&s!=""&&s.length!=0&&e.push(n+"="+p(s))}return e&&e.join("&")}async sign(t){const e="&key="+await this.helloIboot(),n=[];for(const l in t)n.push(l);n.sort((l,d)=>l.toLowerCase().localeCompare(d.toLowerCase()));const s=[];n.forEach(l=>{let d=t[l];typeof d=="object"&&(d=JSON.stringify(d)),s.push(l+"="+d)});const o=s.join("&"),i=j.md5((o+e).toLocaleUpperCase()),c={params:o,md5:i};return h.debug(c,"API_SIGN"),i}assemblyParameter(t,e){const n=t??{};return n.timestamp=Date.now()+"",n.echostr=O(10),n.version=this.version,n.deviceId=this.deviceId,n.webid=this.websiteId,n.apiKey=this.apiKey,e&&e.length>0&&(n.username=e),n}async assemblyHeader({urlParams:t,token:e}){const n={"Content-Type":"application/x-www-form-urlencoded","Res-Type":"json","Device-Id":this.deviceId,"User-Type":e?.utype.toString()??this.userType.toString(),"User-From":this.userFrom,"Api-Key":this.apiKey};this.lang&&this.lang.length>0&&(n.Lang=this.lang),this.websiteId&&this.websiteId.length>0&&(n["Web-Id"]=this.websiteId),this.websiteNo&&this.websiteNo.length>0&&(n["Web-No"]=this.websiteNo),e&&(e.token&&e.token.length>0&&e.username&&e.username.length>0&&(n.Authorization=e.token,n.Username=e.username),e.xcsrf&&(n[e.xcsrf.csrfHeader]=e.xcsrf.csrfToken));const s=R(t),o=await this.sign(s);return n.Sign=o,n}async helloIboot(){if(this.helloMethod.length<=0)return this.apiKey;const t=this.getApiUrl(this.helloMethod),e={"Content-Type":"application/x-www-form-urlencoded","Res-Type":"json","Api-Key":this.apiKey},n={url:t,headers:e};h.debug(n,"HELLO");const s=await fetch(t,{method:"GET",headers:e,credentials:"include",cache:"force-cache"});if(s.ok){const o=await s.json();return h.debug(o.data,"HELLO RESULT"),o.data}throw new Error("hello iBoot error!")}getApiUrl(t){return`${this.baseUrl}/${t}`}async csrf(){const t=await this.get({url:"guest/csrf"});if(t.success){const e=t.data;if(e)return e.csrfToken.toString()}}async get({url:t,data:e,token:n,cache:s="default"}){const o=this.assemblyParameter(e),i=this.convertUrlParameter(o),c=await this.assemblyHeader({urlParams:i,token:n}),l=`${this.getApiUrl(t)}?${i.toString()}`,d={url:l,headers:c};h.info(d,"GET");const u=await fetch(l,{method:"GET",headers:c,credentials:"include",cache:s});if(u.ok){const f=Object.fromEntries(u.headers.entries()),g={...await u.json(),headers:f};return h.debug(g,"GET_RESULT"),g}const E={code:u.status,success:!1,msg:u.statusText};return h.error(E),E}async post({url:t,data:e,token:n,cache:s="default"}){e=e?{...e}:{};const o=e.buffer??void 0,i=e.boundary??void 0;o&&delete e.buffer,i&&delete e.boundary;const c=this.assemblyParameter(e),l=this.convertUrlParameter(c),d=await this.assemblyHeader({urlParams:l,token:n});o&&i&&(d["Content-Type"]=`multipart/form-data; boundary=${i}`);const u=this.getApiUrl(t),E={url:u,headers:d,params:c};h.info(E,"POST");const f=o?`${u}?${l}`:u,g=await fetch(f,{method:"POST",headers:d,body:o||l.toString(),credentials:"include",cache:s});if(g.ok){const Z=Object.fromEntries(g.headers.entries()),L={...await g.json(),headers:Z};return h.debug(L,"POST_RESULT"),L}const C={code:g.status,success:!1,msg:g.statusText};return h.error(C),C}async stream({url:t,data:e,token:n}){e=e?{...e}:{};const s=e.buffer??void 0,o=e.boundary??void 0;s&&delete e.buffer,o&&delete e.boundary;const i=this.assemblyParameter(e),c=this.convertUrlParameter(i),l=await this.assemblyHeader({urlParams:c,token:n});s&&o&&(l["Content-Type"]=`multipart/form-data; boundary=${o}`),l.Connection="keep-alive",l["X-Accel-Buffering"]="no",l["Cache-Control"]="no-cache";const d=this.getApiUrl(t);try{const u=s?`${d}?${c}`:d,E={url:d,headers:l,params:i};h.info(E,"STREAM");const f=await fetch(u,{method:"POST",headers:l,body:s||c.toString(),credentials:"include"});if(!f.ok)throw new Error(`HTTP error! status: ${f.status}`);if(!f.body)throw new Error("No response body");const g=Object.fromEntries(f.headers.entries());return new Response(f.body,{headers:g})}catch(u){throw u}}}a.ACCOUNT_TYPE_MAP=D,a.COOKIE_NAMES=m,a.CURRENT_WEBSITE_KEY=b,a.DEFAULT_LOCALE=U,a.DEVICE_ID_KEY=S,a.HttpClient=Q,a.USER_FORM_MAP=K,a.USER_SEX_MAP=H,a.USER_TYPE_MAP=A,a.cleanToken=z,a.dateFormat=F,a.get=v,a.getHttpOpts=q,a.getLoginUser=V,a.getToken=X,a.iGet=k,a.iPost=G,a.iPostSuccess=Y,a.isArray=w,a.logger=h,a.post=P,a.randomString=O,a.setDefaultRequestHeader=W,a.setToken=J,a.urlEncode=p,a.urlParamToJson=R,Object.defineProperty(a,Symbol.toStringTag,{value:"Module"})}));
1
+ (function(a,T){typeof exports=="object"&&typeof module<"u"?T(exports,require("pino"),require("pino-pretty"),require("js-md5"),require("crypto-js")):typeof define=="function"&&define.amd?define(["exports","pino","pino-pretty","js-md5","crypto-js"],T):(a=typeof globalThis<"u"?globalThis:a||self,T(a["iboot-http-client"]={},a.pino,a.PinoPretty,a.md5,a.CryptoJS))})(this,(function(a,T,B,j,y){"use strict";const D={GENERAL:0,PHONE:1,EMAIL:2},A={TYPE_MGT:0,TYPE_C:1,TYPE_B:2},K={FROM_WEB:1,FROM_PC:2,FROM_WX_MINI_PRO:3,FROM_WX_PLU:4,FROM_WX_E:5,FROM_APP:6,FROM_DEVICE:7},H={unknown:0,male:1,female:2},$=B({colorize:!0,destination:process.stdout,translateTime:"SYS:yyyy-mm-dd HH:MM:ss",ignore:"pid,hostname",messageFormat:"{msg}",singleLine:!0}),h=T({name:process.env.APP_NAME??"iBoot",level:process.env.APP_ENV==="production"?"info":"debug",nestedKey:"payload"},$),w=r=>Array.isArray(r)||typeof r=="object"&&Object.prototype.toString.call(r)==="[object Array]",O=r=>{const t=r||32,e="ABCDEFGHJKMNPQRSTWXYZabcdefhijkmnprstwxyz2345678",n=e.length;let s="";for(let o=0;o<t;o++)s+=e.charAt(Math.floor(Math.random()*n));return s},R=(r,t)=>{const e={};return r.split("&").forEach(s=>{const o=s.split("=");o[1]&&(!t||t.indexOf(o[0])==-1)&&(e[o[0]]=o[1])}),e},p=r=>!r||r==""||r.length==0?"":encodeURIComponent(r).replace(/\(/g,"%28").replace(/\)/g,"%29").replace(/\'/g,"%27").replace(/\!/g,"%21").replace(/\~/g,"%7E"),F=(r,t)=>{const e={"M+":r.getMonth()+1,"d+":r.getDate(),"h+":r.getHours(),"m+":r.getMinutes(),"s+":r.getSeconds(),"q+":Math.floor((r.getMonth()+3)/3),S:r.getMilliseconds()};if(/(y+)/.test(t)){const s=new RegExp(/(y+)/).exec(t);let o=0;s&&s.length>0&&(o=s[0].length),t=t.replace(/(y+)/,r.getFullYear()+"").substring(4-o)}for(const n in e){const s="("+n+")",o=new RegExp(s);if(o.test(t)){const i=o.exec(t);let c=0;i&&i.length>0&&(c=i[0].length),t=t.replace(o,c==1?e[n].toString():("00"+e[n]).substring(e[n].toString().length))}}return t},U="zh-CN",S="_device_id_key",b="_current_website_key",N="Get request error!",I="Post request error!",m={IBOOT_DEVICE_ID:"dvid",IBOOT_LANG:"lang",IBOOT_WEBSITE_ID:"wid",IBOOT_WEBSITE_NO:"wno",IBOOT_TOKEN:"token",IBOOT_USER:"user"},_={DEVICE_ID:"Device-Id",LANG:"Lang",WEBSITE_ID:"Website-Id",WEBSITE_NO:"Website-No"},M=r=>{if(!r.get)throw new Error("The get method of IStorage has not been implemented.");const t=r.get(S)??"",e=r.get(b),n=e!=null?JSON.parse(e):null,s={};return t.length>0&&(s["Device-Id"]=t),n&&(s.Lang=n.language,n.websiteId&&(s["Website-Id"]=n.websiteId),n.websiteNo&&(s["Website-No"]=n.websiteNo)),s},W=({deviceId:r,website:t},e)=>{if(!e.set)throw new Error("The set method of IStorage has not been implemented.");e.set(S,r),t&&e.set(b,JSON.stringify(t))},v=async(r,t)=>{if(t?.data){const i=new URLSearchParams(t.data);r.indexOf("?")!=-1?r+=`&${i}`:r+=`?${i}`}const e=t&&t.storage&&t.storage.get?M(t.storage):{},n=t?.headers;if(n)for(const i in n){const c=n[i];c&&(e[i]=c)}h.info({url:r,headers:e},"GET");const s=await fetch(r,{method:"GET",headers:e,cache:t?.useCache?"force-cache":"default"});if(s.ok){const i=Object.fromEntries(s.headers.entries()),c={...await s.json(),headers:i};return h.debug(c,"GET_RESULT"),c}const o={code:s.status,success:!1,msg:s.statusText};return h.error(o),o},P=async(r,t)=>{const e=t?.data??{},n=t?.headers;let s;const o=t&&t.storage&&t.storage.get?M(t.storage):{},i=new Headers(o);if(e instanceof FormData?s=e:(s=JSON.stringify(e),i.set("Content-Type","application/json")),n)for(let d in n){const u=n[d];u&&i.set(d,u)}h.info({url:r,headers:i},"POST");const c=await fetch(r,{method:"POST",headers:i,body:s});if(c.ok){const d=Object.fromEntries(c.headers.entries()),u={...await c.json(),headers:d};return h.debug(u,"POST_RESULT"),u}const l={code:c.status,success:!1,msg:c.statusText};return h.error(l),l},k=async(r,t)=>{const e=await v(r,t);if(e.success)return e.data;if(t?.showError){t.showError(e.msg??N);return}throw Error(e.msg??N)},G=async(r,t)=>{const e=await P(r,t);if(e.success)return e.data;if(t?.showError){t.showError(e.msg??I);return}throw Error(e.msg??I)},Y=async(r,t)=>{const e=await P(r,t);return e.success?(t?.showSuccess&&t.showSuccess(e.msg??"SUCCESS"),!0):(t?.showError&&t.showError(e.msg??I),!1)},q=r=>{if(r.get){const t=r.get(_.DEVICE_ID),e=r.get(_.LANG),n=r.get(_.WEBSITE_ID),s=r.get(_.WEBSITE_NO),o={};return t&&t.length>0&&(o.deviceId=t),e&&e.length>0&&(o.lang=e),n&&n.length>0&&(o.websiteId=n),s&&s.length>0&&(o.websiteNo=s),o}throw new Error("The set method of IStorage has not been implemented.")},V=r=>{if(r.get){const t=r.get(m.IBOOT_USER);if(t&&t.length>0)return JSON.parse(t)}},X=r=>{if(r.get){const t=r.get(m.IBOOT_USER);if(t&&t.length>0){const e=JSON.parse(t),n=e.username,s=e.userType.toString(),o=r.get(m.IBOOT_TOKEN);if(o)return{username:n,utype:s,token:o}}}},J=(r,t)=>{const{id:e,name:n,username:s,nickname:o,headImg:i,token:c,lastLoginTime:l,deviceId:d,userType:u,mustChangePwd:E}=r,f={id:e,name:n,username:s,nickname:o||n,headImg:i,lastLoginTime:l,deviceId:d,userType:u,accountType:0,needToReview:!1,socketOnline:!1,mustChangePwd:E};if(!t.set)throw new Error("cookies set function is undefined");t.set(m.IBOOT_TOKEN,c,{path:"/",secure:process.env.APP_ENV==="production",httpOnly:!0,sameSite:"strict"}),t.set(m.IBOOT_USER,JSON.stringify(f))},z=r=>{if(!r.set)throw new Error("cookies set function is undefined");if(r.set(m.IBOOT_TOKEN,"",{maxAge:-1,httpOnly:!0,path:"/"}),r.set(m.IBOOT_USER,"",{maxAge:-1,httpOnly:!0,path:"/"}),!r.delete)throw new Error("cookies delete function is undefined");r.delete(m.IBOOT_TOKEN),r.delete(m.IBOOT_USER)};class Q{baseUrl;helloMethod;apiKey;userType;userFrom;deviceId;version="1";lang;websiteId;websiteNo;constructor(t){process.env.APP_ENV==="production"||h.warn("This is currently a development environment!"),this.baseUrl=process.env.APP_BASEURL,this.apiKey=process.env.APP_APIKEY,this.userFrom=process.env.APP_USERFROM??"1",this.helloMethod=t.helloURL??"",this.userType=t.userType??A.TYPE_MGT,this.deviceId=t.deviceId??O(10),this.lang=t.lang??U,this.websiteId=t.websiteId,this.websiteNo=t.websiteNo}encrypt(t){const e=y.enc.Utf8.parse(this.apiKey);return y.AES.encrypt(t,e).toString()}decrypt(t){const e=y.enc.Utf8.parse(this.apiKey);return y.AES.decrypt(t,e,{mode:y.mode.ECB}).toString(y.enc.Utf8)}convertUrlParameter(t){const e=[];for(const n in t){let s=t[n];if(s&&typeof s=="string")s=s.trim();else if(s&&typeof s=="object"){if(w(s)){if(s.length===0)continue;for(let o=0;o<s.length;o++){const i=s[o];for(const c in i){const l=i[c]??void 0;if(l){if(typeof l=="object")w(l)&&l.forEach((d,u)=>{if(d)for(const E in d){const f=d[E];if(f&&f.toString().length>0){const g=`[${o.toString()}].${c+`[${u.toString()}].${E}`}=${p(f)}`;e.push(n+g)}}});else if(l.toString().length>0){const d=`[${o.toString()}].${c}=${p(l.toString())}`;e.push(n+d)}}}}}else for(const o in s){const i=s[o];if(i!=null&&i!=""&&i.length!=0){const c=`.${o}=${p(i)}`;e.push(n+c)}}continue}else s&&typeof s=="function"&&(s=null);s!=null&&s!=""&&s.length!=0&&e.push(n+"="+p(s))}return e&&e.join("&")}async sign(t){const e="&key="+await this.helloIboot(),n=[];for(const l in t)n.push(l);n.sort((l,d)=>l.toLowerCase().localeCompare(d.toLowerCase()));const s=[];n.forEach(l=>{let d=t[l];typeof d=="object"&&(d=JSON.stringify(d)),s.push(l+"="+d)});const o=s.join("&"),i=j.md5((o+e).toLocaleUpperCase()),c={params:o,md5:i};return h.debug(c,"API_SIGN"),i}assemblyParameter(t,e){const n=t??{};return n.timestamp=Date.now()+"",n.echostr=O(10),n.version=this.version,n.deviceId=this.deviceId,n.webid=this.websiteId,n.apiKey=this.apiKey,e&&e.length>0&&(n.username=e),n}async assemblyHeader({urlParams:t,token:e}){const n={"Content-Type":"application/x-www-form-urlencoded","Res-Type":"json","Device-Id":this.deviceId,"User-Type":e?.utype.toString()??this.userType.toString(),"User-From":this.userFrom,"Api-Key":this.apiKey};this.lang&&this.lang.length>0&&(n.Lang=this.lang),this.websiteId&&this.websiteId.length>0&&(n["Web-Id"]=this.websiteId),this.websiteNo&&this.websiteNo.length>0&&(n["Web-No"]=this.websiteNo),e&&(e.token&&e.token.length>0&&e.username&&e.username.length>0&&(n.Authorization=e.token,n.Username=e.username),e.xcsrf&&(n[e.xcsrf.csrfHeader]=e.xcsrf.csrfToken));const s=R(t),o=await this.sign(s);return n.Sign=o,n}async helloIboot(){if(this.helloMethod.length<=0)return this.apiKey;const t=this.getApiUrl(this.helloMethod),e={"Content-Type":"application/x-www-form-urlencoded","Res-Type":"json","Api-Key":this.apiKey},n={url:t,headers:e};h.debug(n,"HELLO");const s=await fetch(t,{method:"GET",headers:e,credentials:"include",cache:"force-cache"});if(s.ok){const o=await s.json();return h.debug(o.data,"HELLO RESULT"),o.data}throw new Error("hello iBoot error!")}getApiUrl(t){return`${this.baseUrl}/${t}`}async csrf(){const t=await this.get({url:"guest/csrf"});if(t.success){const e=t.data;if(e)return e.csrfToken.toString()}}async get({url:t,data:e,token:n,cache:s="default"}){const o=this.assemblyParameter(e),i=this.convertUrlParameter(o),c=await this.assemblyHeader({urlParams:i,token:n}),l=`${this.getApiUrl(t)}?${i.toString()}`,d={url:l,headers:c};h.info(d,"GET");const u=await fetch(l,{method:"GET",headers:c,credentials:"include",cache:s});if(u.ok){const f=Object.fromEntries(u.headers.entries()),g={...await u.json(),headers:f};return h.debug(g,"GET_RESULT"),g}const E={code:u.status,success:!1,msg:u.statusText};return h.error(E),E}async post({url:t,data:e,token:n,cache:s="default"}){e=e?{...e}:{};const o=e.buffer??void 0,i=e.boundary??void 0;o&&delete e.buffer,i&&delete e.boundary;const c=this.assemblyParameter(e),l=this.convertUrlParameter(c),d=await this.assemblyHeader({urlParams:l,token:n});o&&i&&(d["Content-Type"]=`multipart/form-data; boundary=${i}`);const u=this.getApiUrl(t),E={url:u,headers:d,params:c};h.info(E,"POST");const f=o?`${u}?${l}`:u,g=await fetch(f,{method:"POST",headers:d,body:o||l.toString(),credentials:"include",cache:s});if(g.ok){const Z=Object.fromEntries(g.headers.entries()),L={...await g.json(),headers:Z};return h.debug(L,"POST_RESULT"),L}const C={code:g.status,success:!1,msg:g.statusText};return h.error(C),C}async stream({url:t,data:e,token:n}){e=e?{...e}:{};const s=e.buffer??void 0,o=e.boundary??void 0;s&&delete e.buffer,o&&delete e.boundary;const i=this.assemblyParameter(e),c=this.convertUrlParameter(i),l=await this.assemblyHeader({urlParams:c,token:n});s&&o&&(l["Content-Type"]=`multipart/form-data; boundary=${o}`),l.Connection="keep-alive",l["X-Accel-Buffering"]="no",l["Cache-Control"]="no-cache";const d=this.getApiUrl(t);try{const u=s?`${d}?${c}`:d,E={url:d,headers:l,params:i};h.info(E,"STREAM");const f=await fetch(u,{method:"POST",headers:l,body:s||c.toString(),credentials:"include"});if(!f.ok)throw new Error(`HTTP error! status: ${f.status}`);if(!f.body)throw new Error("No response body");const g=Object.fromEntries(f.headers.entries());return new Response(f.body,{headers:g})}catch(u){throw u}}}a.ACCOUNT_TYPE_MAP=D,a.COOKIE_NAMES=m,a.CURRENT_WEBSITE_KEY=b,a.DEFAULT_LOCALE=U,a.DEVICE_ID_KEY=S,a.HEADER_NAMES=_,a.HttpClient=Q,a.USER_FORM_MAP=K,a.USER_SEX_MAP=H,a.USER_TYPE_MAP=A,a.cleanToken=z,a.dateFormat=F,a.get=v,a.getHttpOpts=q,a.getLoginUser=V,a.getToken=X,a.iGet=k,a.iPost=G,a.iPostSuccess=Y,a.isArray=w,a.logger=h,a.post=P,a.randomString=O,a.setDefaultRequestHeader=W,a.setToken=J,a.urlEncode=p,a.urlParamToJson=R,Object.defineProperty(a,Symbol.toStringTag,{value:"Module"})}));
2
2
  //# sourceMappingURL=iboot-http-client.umd.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"iboot-http-client.umd.js","sources":["../src/types/user.ts","../src/logger.ts","../src/utils.ts","../src/http-client.ts"],"sourcesContent":["export const ACCOUNT_TYPE_MAP = {\r\n GENERAL : 0,\r\n PHONE : 1,\r\n EMAIL : 2\r\n}\r\n\r\nexport const USER_TYPE_MAP = {\r\n TYPE_MGT : 0,\r\n TYPE_C : 1,\r\n TYPE_B : 2\r\n}\r\n\r\nexport const USER_FORM_MAP = {\r\n FROM_WEB : 1,\r\n FROM_PC : 2,\r\n FROM_WX_MINI_PRO : 3,\r\n FROM_WX_PLU : 4,\r\n FROM_WX_E : 5,\r\n FROM_APP : 6,\r\n FROM_DEVICE : 7\r\n}\r\n\r\nexport const USER_SEX_MAP = {\r\n unknown:0,\r\n male:1,\r\n female:2,\r\n}\r\n\r\nexport type ACCOUNT_TYPE = typeof ACCOUNT_TYPE_MAP[keyof typeof ACCOUNT_TYPE_MAP];\r\nexport type USER_TYPE = typeof USER_TYPE_MAP[keyof typeof USER_TYPE_MAP];\r\nexport type USER_FORM = typeof USER_FORM_MAP[keyof typeof USER_FORM_MAP];\r\nexport type USER_SEX = typeof USER_SEX_MAP[keyof typeof USER_SEX_MAP];\r\n\r\n// User interface\r\nexport interface User {\r\n id: string;\r\n name: string;\r\n userType: USER_TYPE;\r\n username?: string;\r\n nickname?: string;\r\n sex?: USER_SEX;\r\n headImg?: string;\r\n lastLoginTime?: string;\r\n tokenExpired?: string;\r\n deviceId?: string;\r\n status?: number;\r\n accountType?: number;\r\n enabled?: boolean;\r\n userFrom?: USER_FORM;\r\n needToReview?: boolean;\r\n socketOnline?: boolean;\r\n createTime?: string;\r\n mustChangePwd?: boolean;\r\n}","import pino from \"pino\";\r\nimport PinoPretty from \"pino-pretty\";\r\n// import koffi from 'koffi';\r\n\r\n// if (typeof window === 'undefined' && process.platform === 'win32') {\r\n// try {\r\n// const CP_UTF8 = 65001;\r\n// const kernel32 = koffi.load('Kernel32');\r\n// const setConsoleOutputCP = kernel32.func('SetConsoleOutputCP', 'bool', ['int']);\r\n// const setConsoleCP = kernel32.func('SetConsoleCP', 'bool', ['int']);\r\n// setConsoleOutputCP(CP_UTF8);\r\n// setConsoleCP(CP_UTF8);\r\n// } catch (e) {\r\n// console.log(e);\r\n// }\r\n// }\r\n\r\n// export const logger = pino({\r\n// name: process.env.APP_NAME ?? 'iBoot',\r\n// level: process.env.NODE_ENV !== 'production' ? 'debug' : 'info',\r\n// nestedKey: 'payload',\r\n// transport: {\r\n// target: 'pino-pretty',\r\n// options: {\r\n// colorize: true,\r\n// translateTime: 'SYS:yyyy-mm-dd HH:MM:ss',\r\n// ignore: 'pid,hostname',\r\n// messageFormat: '{msg}',\r\n// singleLine: true,\r\n// },\r\n// }\r\n// });\r\n\r\nconst stream = PinoPretty({\r\n colorize: true,\r\n destination: process.stdout,\r\n translateTime: 'SYS:yyyy-mm-dd HH:MM:ss',\r\n ignore: 'pid,hostname',\r\n messageFormat: '{msg}',\r\n singleLine: true,\r\n});\r\n\r\nexport const logger = pino({\r\n name: process.env.APP_NAME ?? 'iBoot',\r\n level: process.env.APP_ENV === 'production' ? 'info' : 'debug',\r\n nestedKey: 'payload'\r\n}, stream);","export const isArray = (obj: unknown) => {\r\n return (\r\n Array.isArray(obj) ||\r\n (typeof obj === \"object\" &&\r\n Object.prototype.toString.call(obj) === \"[object Array]\")\r\n );\r\n};\r\n\r\n/**\r\n * 生成指定长度的随机串\r\n * @param {Object} len\r\n */\r\nexport const randomString = (len: number) => {\r\n const l = len || 32;\r\n const $chars = \"ABCDEFGHJKMNPQRSTWXYZabcdefhijkmnprstwxyz2345678\";\r\n const maxPos = $chars.length;\r\n let pwd = \"\";\r\n for (let i = 0; i < l; i++) {\r\n pwd += $chars.charAt(Math.floor(Math.random() * maxPos));\r\n }\r\n return pwd;\r\n};\r\n\r\nexport const urlParamToJson = (urlQueryParams: string, exclude?: string[]): Record<string, string> => {\r\n const result: Record<string, string> = {};\r\n const strs = urlQueryParams.split(\"&\");\r\n strs.forEach((item) => {\r\n const arr = item.split(\"=\");\r\n if (arr[1]) {\r\n if (!exclude || exclude.indexOf(arr[0]) == -1) {\r\n result[arr[0]] = arr[1];\r\n }\r\n }\r\n });\r\n return result;\r\n};\r\n\r\nexport const urlEncode = (value: string | null | undefined): string => {\r\n if (!value || value == \"\" || value.length == 0) {\r\n return \"\";\r\n }\r\n return (\r\n encodeURIComponent(value)\r\n // .replace(/%20/g, '+')\r\n // .replace(/%2B/g, '\\\\+')\r\n .replace(/\\(/g, \"%28\")\r\n .replace(/\\)/g, \"%29\")\r\n .replace(/\\'/g, \"%27\")\r\n .replace(/\\!/g, \"%21\")\r\n .replace(/\\~/g, \"%7E\")\r\n );\r\n};\r\n\r\nexport const dateFormat = (dt: Date, fmt: string) => {\r\n const o:Record<string, number> = {\r\n \"M+\": dt.getMonth() + 1, //月份\r\n \"d+\": dt.getDate(), //日\r\n \"h+\": dt.getHours(), //小时\r\n \"m+\": dt.getMinutes(), //分\r\n \"s+\": dt.getSeconds(), //秒\r\n \"q+\": Math.floor((dt.getMonth() + 3) / 3), //季度\r\n S: dt.getMilliseconds(), //毫秒\r\n };\r\n if (/(y+)/.test(fmt)){\r\n const regx = new RegExp(/(y+)/);\r\n const value = regx.exec(fmt);\r\n let len = 0;\r\n if(value && value.length > 0){\r\n len = value[0].length;\r\n }\r\n fmt = fmt.replace(/(y+)/, dt.getFullYear() + \"\").substring(4 - len);\r\n }\r\n\r\n for (const k in o){\r\n const s:string = \"(\" + k + \")\";\r\n const regx = new RegExp(s);\r\n if(regx.test(fmt)){\r\n const value = regx.exec(fmt);\r\n let len = 0;\r\n if(value && value.length > 0){\r\n len = value[0].length;\r\n }\r\n fmt = fmt.replace(regx, len == 1 ? o[k].toString() : (\"00\" + o[k]).substring(o[k].toString().length))\r\n }\r\n }\r\n return fmt;\r\n}","import md5 from \"js-md5\";\r\nimport CryptoJS from 'crypto-js';\r\nimport { isArray, randomString, urlEncode, urlParamToJson } from \"./utils\";\r\nimport {\r\n ClientGetParams,\r\n ClientPostParams,\r\n CSRFToken,\r\n CurWebsite,\r\n HttpClientOpts,\r\n HttpHeaders,\r\n HttpToken,\r\n ResultModel,\r\n ServerRequestOptions,\r\n ICookies,\r\n IStorage\r\n} from \"./types/http\";\r\nimport { User, USER_TYPE, USER_TYPE_MAP } from \"./types/user\";\r\nimport { logger } from \"./logger\";\r\n\r\n\r\nexport const DEFAULT_LOCALE = 'zh-CN';\r\nexport const DEVICE_ID_KEY = \"_device_id_key\";\r\nexport const CURRENT_WEBSITE_KEY = \"_current_website_key\"\r\n\r\nconst _GET_ERROR = \"Get request error!\"\r\nconst _POST_ERROR = \"Post request error!\";\r\n\r\nexport const COOKIE_NAMES = {\r\n \"IBOOT_DEVICE_ID\": \"dvid\",\r\n \"IBOOT_LANG\": \"lang\",\r\n \"IBOOT_WEBSITE_ID\": \"wid\",\r\n \"IBOOT_WEBSITE_NO\": \"wno\",\r\n \"IBOOT_TOKEN\": \"token\",\r\n \"IBOOT_USER\": \"user\"\r\n}\r\n\r\nconst HEADER_NAMES = {\r\n \"DEVICE_ID\": \"Device-Id\",\r\n \"LANG\": \"Lang\",\r\n \"WEBSITE_ID\": \"Website-Id\",\r\n \"WEBSITE_NO\": \"Website-No\",\r\n}\r\n\r\n\r\nconst getDefaultRequestHeader = (storage: Readonly<IStorage>): HttpHeaders => {\r\n if (!storage.get) {\r\n throw new Error(\"The get method of IStorage has not been implemented.\")\r\n }\r\n const devideId = storage.get(DEVICE_ID_KEY) ?? ''\r\n const json = storage.get(CURRENT_WEBSITE_KEY);\r\n const curWebsite: CurWebsite | null = json != null ? JSON.parse(json) : null;\r\n const header: HttpHeaders = {}\r\n if (devideId.length > 0) {\r\n header['Device-Id'] = devideId\r\n }\r\n if (curWebsite) {\r\n header['Lang'] = curWebsite.language;\r\n if (curWebsite.websiteId) {\r\n header['Website-Id'] = curWebsite.websiteId;\r\n }\r\n if (curWebsite.websiteNo) {\r\n header['Website-No'] = curWebsite.websiteNo\r\n }\r\n }\r\n return header;\r\n};\r\n\r\n\r\nexport const setDefaultRequestHeader = ({ deviceId, website }: Readonly<{ deviceId: string, website?: CurWebsite }>, storage: IStorage): void => {\r\n if (!storage.set) {\r\n throw new Error(\"The set method of IStorage has not been implemented.\")\r\n }\r\n storage.set(DEVICE_ID_KEY, deviceId);\r\n if (website) {\r\n storage.set(CURRENT_WEBSITE_KEY, JSON.stringify(website));\r\n }\r\n}\r\n\r\nexport const get = async <T>(url: string, opts?: ClientGetParams): Promise<ResultModel<T>> => {\r\n if (opts?.data) {\r\n const params = new URLSearchParams(opts.data);\r\n if (url.indexOf(\"?\") != -1) {\r\n url += `&${params}`\r\n } else {\r\n url += `?${params}`\r\n }\r\n }\r\n const headers: Record<string, string> = (opts && opts.storage && opts.storage.get) ? getDefaultRequestHeader(opts.storage) : {}\r\n const heads = opts?.headers;\r\n if (heads) {\r\n for (const field in heads) {\r\n const value = heads[field];\r\n if (value) {\r\n headers[field] = value;\r\n }\r\n }\r\n }\r\n logger.info({\r\n \"url\": url,\r\n \"headers\": headers,\r\n }, \"GET\")\r\n const res = await fetch(url, {\r\n method: 'GET',\r\n headers: headers,\r\n cache: opts?.useCache ? 'force-cache' : 'default'\r\n });\r\n\r\n if (res.ok) {\r\n const headersMap = Object.fromEntries(res.headers.entries());\r\n const result = { ...await res.json(), headers: headersMap };\r\n logger.debug(result, \"GET_RESULT\")\r\n return result\r\n }\r\n const msg = {\r\n code: res.status,\r\n success: false,\r\n msg: res.statusText\r\n }\r\n logger.error(msg);\r\n return msg;\r\n}\r\n\r\nexport const post = async <T>(url: string, opts?: ClientPostParams): Promise<ResultModel<T>> => {\r\n const data = opts?.data ?? {};\r\n const heads = opts?.headers;\r\n let body: string | FormData;\r\n const defaultHeads = (opts && opts.storage && opts.storage.get) ? getDefaultRequestHeader(opts.storage) : {}\r\n const proxyHeaders = new Headers(defaultHeads);\r\n if (!(data instanceof FormData)) {\r\n body = JSON.stringify(data);\r\n proxyHeaders.set('Content-Type', 'application/json');\r\n } else {\r\n body = data;\r\n }\r\n if (heads) {\r\n for (let field in heads) {\r\n const value = heads[field];\r\n if (value) {\r\n proxyHeaders.set(field, value);\r\n }\r\n }\r\n }\r\n logger.info({\r\n \"url\": url,\r\n \"headers\": proxyHeaders,\r\n }, \"POST\")\r\n const res = await fetch(url, {\r\n method: 'POST',\r\n headers: proxyHeaders,\r\n body: body,\r\n });\r\n if (res.ok) {\r\n const headersMap = Object.fromEntries(res.headers.entries());\r\n const result = { ...await res.json(), headers: headersMap };\r\n logger.debug(result, \"POST_RESULT\")\r\n return result\r\n }\r\n const msg = {\r\n code: res.status,\r\n success: false,\r\n msg: res.statusText,\r\n }\r\n logger.error(msg);\r\n return msg;\r\n}\r\n\r\nexport const iGet = async <T>(url: string, opts?: ClientGetParams): Promise<T | undefined> => {\r\n const res = await get<T>(url, opts);\r\n if (res.success) {\r\n return res.data as T;\r\n }\r\n if (opts?.showError) {\r\n opts.showError(res.msg ?? _GET_ERROR);\r\n return;\r\n }\r\n throw Error(res.msg ?? _GET_ERROR)\r\n}\r\n\r\nexport const iPost = async <T>(url: string, opts?: ClientPostParams): Promise<T | undefined> => {\r\n const res = await post<T>(url, opts);\r\n if (res.success) {\r\n return res.data;\r\n }\r\n if (opts?.showError) {\r\n opts.showError(res.msg ?? _POST_ERROR);\r\n return;\r\n }\r\n throw Error(res.msg ?? _POST_ERROR)\r\n}\r\n\r\nexport const iPostSuccess = async (url: string, opts?: ClientPostParams): Promise<boolean> => {\r\n const res = await post(url, opts);\r\n if (res.success) {\r\n if (opts?.showSuccess) {\r\n opts.showSuccess(res.msg ?? 'SUCCESS')\r\n }\r\n return true;\r\n }\r\n if (opts?.showError) {\r\n opts.showError(res.msg ?? _POST_ERROR);\r\n }\r\n return false;\r\n}\r\n\r\nexport const getHttpOpts = (storage: IStorage): HttpClientOpts => {\r\n if (storage.get) {\r\n const deviceId = storage.get(HEADER_NAMES.DEVICE_ID);\r\n const lang = storage.get(HEADER_NAMES.LANG);\r\n const websiteId = storage.get(HEADER_NAMES.WEBSITE_ID);\r\n const websiteNo = storage.get(HEADER_NAMES.WEBSITE_NO);\r\n const result: HttpClientOpts = {}\r\n if (deviceId && deviceId.length > 0) {\r\n result.deviceId = deviceId;\r\n }\r\n if (lang && lang.length > 0) {\r\n result.lang = lang\r\n }\r\n if (websiteId && websiteId.length > 0) {\r\n result.websiteId = websiteId\r\n }\r\n if (websiteNo && websiteNo.length > 0) {\r\n result.websiteNo = websiteNo\r\n }\r\n return result;\r\n }\r\n throw new Error(\"The set method of IStorage has not been implemented.\")\r\n}\r\n\r\nexport const getLoginUser = (cookies: ICookies): User | undefined => {\r\n if (cookies.get) {\r\n const userjson = cookies.get(COOKIE_NAMES.IBOOT_USER)\r\n if (userjson && userjson.length > 0) {\r\n return JSON.parse(userjson);\r\n }\r\n }\r\n return undefined\r\n}\r\n\r\nexport const getToken = (cookies: ICookies): HttpToken | undefined => {\r\n if (cookies.get) {\r\n const userjson = cookies.get(COOKIE_NAMES.IBOOT_USER);\r\n if (userjson && userjson.length > 0) {\r\n const user = JSON.parse(userjson);\r\n const username = user.username;\r\n const utype = user.userType.toString();\r\n const token = cookies.get(COOKIE_NAMES.IBOOT_TOKEN);\r\n if (token) {\r\n return {\r\n \"username\": username,\r\n \"utype\": utype,\r\n \"token\": token\r\n }\r\n }\r\n }\r\n }\r\n return undefined\r\n}\r\n\r\nexport const setToken = (data: User & { token: string }, cookies: ICookies): void => {\r\n const { id, name, username, nickname, headImg, token, lastLoginTime, deviceId, userType, mustChangePwd } = data;\r\n const loginUser: User = {\r\n id: id,\r\n name: name,\r\n username: username,\r\n nickname: nickname || name,\r\n headImg: headImg,\r\n lastLoginTime: lastLoginTime,\r\n deviceId: deviceId,\r\n userType: userType,\r\n accountType: 0,\r\n needToReview: false,\r\n socketOnline: false,\r\n mustChangePwd: mustChangePwd\r\n };\r\n if (!cookies.set) {\r\n throw new Error('cookies set function is undefined')\r\n }\r\n cookies.set(COOKIE_NAMES.IBOOT_TOKEN, token, {\r\n path: '/',\r\n secure: process.env.APP_ENV === 'production',\r\n httpOnly: true,\r\n sameSite: 'strict'\r\n });\r\n cookies.set(COOKIE_NAMES.IBOOT_USER, JSON.stringify(loginUser))\r\n}\r\n\r\nexport const cleanToken = (cookies: ICookies): void => {\r\n if (!cookies.set) {\r\n throw new Error('cookies set function is undefined')\r\n }\r\n cookies.set(COOKIE_NAMES.IBOOT_TOKEN, '', {\r\n maxAge: -1, //设置为 -1表示立即过期\r\n httpOnly: true,\r\n path: '/',\r\n });\r\n cookies.set(COOKIE_NAMES.IBOOT_USER, '', {\r\n maxAge: -1, //设置为 -1表示立即过期\r\n httpOnly: true,\r\n path: '/',\r\n });\r\n if (!cookies.delete) {\r\n throw new Error('cookies delete function is undefined')\r\n }\r\n cookies.delete(COOKIE_NAMES.IBOOT_TOKEN);\r\n cookies.delete(COOKIE_NAMES.IBOOT_USER);\r\n}\r\n\r\nexport class HttpClient {\r\n private readonly baseUrl: string;\r\n private readonly helloMethod: string;\r\n private readonly apiKey: string;\r\n private readonly userType: USER_TYPE;\r\n private readonly userFrom: string;\r\n private readonly deviceId: string;\r\n private readonly version: string = '1';\r\n private readonly lang: string;\r\n private readonly websiteId?: string;\r\n private readonly websiteNo?: string;\r\n constructor(opts: Readonly<HttpClientOpts>) {\r\n const isProduction = process.env.APP_ENV === 'production';\r\n if (!isProduction) {\r\n logger.warn(\"This is currently a development environment!\")\r\n }\r\n this.baseUrl = process.env.APP_BASEURL!;\r\n this.apiKey = process.env.APP_APIKEY!;\r\n this.userFrom = process.env.APP_USERFROM ?? '1';\r\n\r\n this.helloMethod = opts.helloURL ?? ''\r\n this.userType = opts.userType ?? USER_TYPE_MAP.TYPE_MGT;\r\n this.deviceId = opts.deviceId ?? randomString(10);\r\n this.lang = opts.lang ?? DEFAULT_LOCALE;\r\n this.websiteId = opts.websiteId\r\n this.websiteNo = opts.websiteNo\r\n }\r\n\r\n encrypt(data: string) {\r\n const key = CryptoJS.enc.Utf8.parse(this.apiKey);\r\n return CryptoJS.AES.encrypt(data, key).toString();\r\n }\r\n\r\n decrypt(data: string) {\r\n const key = CryptoJS.enc.Utf8.parse(this.apiKey);\r\n return CryptoJS.AES.decrypt(data, key, {\r\n mode: CryptoJS.mode.ECB,\r\n }).toString(CryptoJS.enc.Utf8);\r\n }\r\n\r\n //eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n private convertUrlParameter(data: Record<string, any>): string {\r\n const p: string[] = [];\r\n for (const o in data) {\r\n let v = data[o];\r\n if (v && typeof v === \"string\") {\r\n v = v.trim();\r\n } else if (v && typeof v === \"object\") {\r\n if (isArray(v)) {\r\n if (v.length === 0) {\r\n continue;\r\n }\r\n for (let i = 0; i < v.length; i++) {\r\n const arr_item = v[i];\r\n for (const item_field in arr_item) {\r\n const item_field_value = arr_item[item_field] ?? undefined;\r\n if (item_field_value) {\r\n if (typeof item_field_value === \"object\") {\r\n if (isArray(item_field_value)) {\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n item_field_value.forEach((item1: any, index: number) => {\r\n if (item1) {\r\n for (const f in item1) {\r\n const v = item1[f];\r\n if (v && v.toString().length > 0) {\r\n const s = `[${i.toString()}].${item_field + `[${index.toString()}].${f}`}=${urlEncode(v)}`;\r\n p.push(o + s);\r\n }\r\n }\r\n }\r\n });\r\n }\r\n } else if (item_field_value.toString().length > 0) {\r\n const s = `[${i.toString()}].${item_field}=${urlEncode(item_field_value.toString())}`;\r\n p.push(o + s);\r\n }\r\n }\r\n }\r\n }\r\n } else {\r\n for (const obj in v) {\r\n const oValue = v[obj];\r\n if (oValue != null && oValue != \"\" && oValue.length != 0) {\r\n const s = `.${obj}=${urlEncode(oValue)}`;\r\n p.push(o + s);\r\n }\r\n }\r\n }\r\n continue;\r\n } else if (v && typeof v === \"function\") {\r\n v = null;\r\n }\r\n\r\n if (v != null && v != \"\" && v.length != 0) {\r\n p.push(o + \"=\" + urlEncode(v));\r\n }\r\n }\r\n return (p && p.join(\"&\"));\r\n }\r\n\r\n private async sign(data: Record<string, object | string>): Promise<string> {\r\n //由后台分配\r\n const _apiKey = \"&key=\" + (await this.helloIboot());\r\n const arr: string[] = [];\r\n for (const o in data) {\r\n arr.push(o);\r\n }\r\n arr.sort((a: string, b: string) => {\r\n return a.toLowerCase().localeCompare(b.toLowerCase());\r\n });\r\n const res: string[] = [];\r\n arr.forEach((v: string) => {\r\n let value: object | string = data[v];\r\n if (typeof value === \"object\") {\r\n value = JSON.stringify(value);\r\n }\r\n res.push(v + \"=\" + value);\r\n });\r\n const paramsStr: string = res.join(\"&\");\r\n const str = md5.md5((paramsStr + _apiKey).toLocaleUpperCase());\r\n const logInfo = {\r\n params: paramsStr,\r\n md5: str\r\n }\r\n logger.debug(logInfo, \"API_SIGN\")\r\n return str;\r\n }\r\n\r\n //eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n private assemblyParameter(data?: Record<string, any>, username?: string): Record<string, any> {\r\n const params = data ?? {};\r\n params['timestamp'] = Date.now() + '';\r\n params['echostr'] = randomString(10);\r\n params['version'] = this.version;\r\n params['deviceId'] = this.deviceId;\r\n params['webid'] = this.websiteId;\r\n params['apiKey'] = this.apiKey;\r\n if (username && username.length > 0) {\r\n params['username'] = username;\r\n }\r\n return params;\r\n }\r\n\r\n private async assemblyHeader({ urlParams, token }: Readonly<{ urlParams: string, token?: Readonly<HttpToken> }>) {\r\n const h: Record<string, string> = {\r\n 'Content-Type': 'application/x-www-form-urlencoded',\r\n 'Res-Type': 'json',\r\n 'Device-Id': this.deviceId,\r\n 'User-Type': token?.utype.toString() ?? this.userType.toString(),\r\n 'User-From': this.userFrom,\r\n 'Api-Key': this.apiKey\r\n }\r\n if (this.lang && this.lang.length > 0) {\r\n h['Lang'] = this.lang\r\n }\r\n if (this.websiteId && this.websiteId.length > 0) {\r\n h['Web-Id'] = this.websiteId\r\n }\r\n if (this.websiteNo && this.websiteNo.length > 0) {\r\n h['Web-No'] = this.websiteNo\r\n }\r\n if (token) {\r\n if (token.token && token.token.length > 0 && token.username && token.username.length > 0) {\r\n h['Authorization'] = token.token;\r\n h['Username'] = token.username;\r\n }\r\n if (token.xcsrf) {\r\n h[token.xcsrf.csrfHeader] = token.xcsrf.csrfToken;\r\n }\r\n }\r\n const data = urlParamToJson(urlParams);\r\n const sign = await this.sign(data);\r\n h['Sign'] = sign\r\n return h;\r\n }\r\n\r\n private async helloIboot(): Promise<string> {\r\n if (this.helloMethod.length <= 0) {\r\n return this.apiKey;\r\n }\r\n const api = this.getApiUrl(this.helloMethod);\r\n const h = {\r\n 'Content-Type': 'application/x-www-form-urlencoded',\r\n 'Res-Type': 'json',\r\n 'Api-Key': this.apiKey\r\n }\r\n const logInfo = {\r\n \"url\": api,\r\n \"headers\": h\r\n }\r\n logger.debug(logInfo, \"HELLO\");\r\n const res = await fetch(api, {\r\n method: 'GET',\r\n headers: h,\r\n credentials: 'include',\r\n cache: 'force-cache'\r\n });\r\n if (res.ok) {\r\n const result = await res.json();\r\n logger.debug(result.data, 'HELLO RESULT')\r\n return result.data;\r\n }\r\n throw new Error('hello iBoot error!')\r\n }\r\n\r\n private getApiUrl(url: string): string {\r\n return `${this.baseUrl}/${url}`;\r\n }\r\n\r\n async csrf(): Promise<string | undefined> {\r\n const res = await this.get<CSRFToken>({\r\n url: 'guest/csrf'\r\n });\r\n if (res.success) {\r\n const data = res.data;\r\n if (data) {\r\n return data[\"csrfToken\"].toString();\r\n }\r\n }\r\n return undefined;\r\n }\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n async get<T>({ url, data, token, cache = 'default' }: Readonly<ServerRequestOptions>): Promise<ResultModel<T>> {\r\n const params = this.assemblyParameter(data);\r\n const urlParams = this.convertUrlParameter(params);\r\n const headers = await this.assemblyHeader({ \"urlParams\": urlParams, \"token\": token });\r\n const api = `${this.getApiUrl(url)}?${urlParams.toString()}`\r\n const logInfo = {\r\n \"url\": api,\r\n \"headers\": headers\r\n }\r\n logger.info(logInfo, \"GET\");\r\n const res = await fetch(api, {\r\n \"method\": 'GET',\r\n \"headers\": headers,\r\n \"credentials\": 'include',\r\n \"cache\": cache\r\n });\r\n if (res.ok) {\r\n const headersMap = Object.fromEntries(res.headers.entries());\r\n const result = { ...await res.json(), headers: headersMap };\r\n logger.debug(result, \"GET_RESULT\")\r\n return result;\r\n }\r\n const msg = {\r\n code: res.status,\r\n success: false,\r\n msg: res.statusText\r\n }\r\n logger.error(msg);\r\n return msg;\r\n }\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n async post<T>({ url, data, token, cache = \"default\" }: Readonly<ServerRequestOptions>): Promise<ResultModel<T>> {\r\n data = data ? { ...data } : {}\r\n const buffer = data.buffer ?? undefined;\r\n const boundary = data.boundary ?? undefined;\r\n if (buffer) {\r\n delete data.buffer;\r\n }\r\n if (boundary) {\r\n delete data.boundary;\r\n }\r\n const params = this.assemblyParameter(data);\r\n const urlParams = this.convertUrlParameter(params);\r\n const headers = await this.assemblyHeader({ \"urlParams\": urlParams, \"token\": token });\r\n if (buffer && boundary) {\r\n headers['Content-Type'] = `multipart/form-data; boundary=${boundary}`;\r\n }\r\n const api = this.getApiUrl(url);\r\n const logInfo = {\r\n \"url\": api,\r\n \"headers\": headers,\r\n \"params\": params\r\n }\r\n logger.info(logInfo, \"POST\");\r\n const urls = buffer ? `${api}?${urlParams}` : api;\r\n const res = await fetch(urls, {\r\n \"method\": 'POST',\r\n \"headers\": headers,\r\n \"body\": buffer ? buffer : urlParams.toString(),\r\n \"credentials\": 'include',\r\n \"cache\": cache\r\n });\r\n if (res.ok) {\r\n const headersMap = Object.fromEntries(res.headers.entries());\r\n const result = { ...await res.json(), headers: headersMap };\r\n logger.debug(result, \"POST_RESULT\");\r\n return result;\r\n }\r\n const msg = {\r\n code: res.status,\r\n success: false,\r\n msg: res.statusText\r\n }\r\n logger.error(msg);\r\n return msg;\r\n }\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n async stream({ url, data, token }: Readonly<Omit<ServerRequestOptions, 'cache'>>): Promise<Response> {\r\n data = data ? { ...data } : {}\r\n const buffer = data.buffer ?? undefined;\r\n const boundary = data.boundary ?? undefined;\r\n if (buffer) {\r\n delete data.buffer;\r\n }\r\n if (boundary) {\r\n delete data.boundary;\r\n }\r\n const params = this.assemblyParameter(data);\r\n const urlParams = this.convertUrlParameter(params); //new URLSearchParams(params);\r\n\r\n const headers = await this.assemblyHeader({ \"urlParams\": urlParams, \"token\": token });\r\n if (buffer && boundary) {\r\n headers['Content-Type'] = `multipart/form-data; boundary=${boundary}`;\r\n }\r\n headers['Connection'] = 'keep-alive';\r\n headers['X-Accel-Buffering'] = 'no'; //防止 Nginx 缓存\r\n headers['Cache-Control'] = 'no-cache';\r\n const api = this.getApiUrl(url)\r\n try {\r\n const url = buffer ? `${api}?${urlParams}` : api;\r\n const logInfo = {\r\n \"url\": api,\r\n \"headers\": headers,\r\n \"params\": params\r\n }\r\n logger.info(logInfo, \"STREAM\");\r\n const res = await fetch(url, {\r\n method: 'POST',\r\n headers: headers,\r\n body: buffer ? buffer : urlParams.toString(),\r\n credentials: 'include'\r\n });\r\n\r\n if (!res.ok) {\r\n throw new Error(`HTTP error! status: ${res.status}`);\r\n }\r\n if (!res.body) {\r\n throw new Error('No response body');\r\n }\r\n const headersMap = Object.fromEntries(res.headers.entries());\r\n return new Response(res.body, {\r\n headers: headersMap\r\n });\r\n } catch (e) {\r\n throw e;\r\n }\r\n }\r\n}"],"names":["ACCOUNT_TYPE_MAP","USER_TYPE_MAP","USER_FORM_MAP","USER_SEX_MAP","stream","PinoPretty","logger","pino","isArray","obj","randomString","len","l","$chars","maxPos","pwd","i","urlParamToJson","urlQueryParams","exclude","result","item","arr","urlEncode","value","dateFormat","dt","fmt","o","k","regx","DEFAULT_LOCALE","DEVICE_ID_KEY","CURRENT_WEBSITE_KEY","_GET_ERROR","_POST_ERROR","COOKIE_NAMES","HEADER_NAMES","getDefaultRequestHeader","storage","devideId","json","curWebsite","header","setDefaultRequestHeader","deviceId","website","get","url","opts","params","headers","heads","field","res","headersMap","msg","post","data","body","defaultHeads","proxyHeaders","iGet","iPost","iPostSuccess","getHttpOpts","lang","websiteId","websiteNo","getLoginUser","cookies","userjson","getToken","user","username","utype","token","setToken","id","name","nickname","headImg","lastLoginTime","userType","mustChangePwd","loginUser","cleanToken","HttpClient","key","CryptoJS","p","v","arr_item","item_field","item_field_value","item1","index","f","s","oValue","_apiKey","a","b","paramsStr","str","md5","logInfo","urlParams","h","sign","api","cache","buffer","boundary","urls","e"],"mappings":"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"}
1
+ {"version":3,"file":"iboot-http-client.umd.js","sources":["../src/types/user.ts","../src/logger.ts","../src/utils.ts","../src/http-client.ts"],"sourcesContent":["export const ACCOUNT_TYPE_MAP = {\r\n GENERAL : 0,\r\n PHONE : 1,\r\n EMAIL : 2\r\n}\r\n\r\nexport const USER_TYPE_MAP = {\r\n TYPE_MGT : 0,\r\n TYPE_C : 1,\r\n TYPE_B : 2\r\n}\r\n\r\nexport const USER_FORM_MAP = {\r\n FROM_WEB : 1,\r\n FROM_PC : 2,\r\n FROM_WX_MINI_PRO : 3,\r\n FROM_WX_PLU : 4,\r\n FROM_WX_E : 5,\r\n FROM_APP : 6,\r\n FROM_DEVICE : 7\r\n}\r\n\r\nexport const USER_SEX_MAP = {\r\n unknown:0,\r\n male:1,\r\n female:2,\r\n}\r\n\r\nexport type ACCOUNT_TYPE = typeof ACCOUNT_TYPE_MAP[keyof typeof ACCOUNT_TYPE_MAP];\r\nexport type USER_TYPE = typeof USER_TYPE_MAP[keyof typeof USER_TYPE_MAP];\r\nexport type USER_FORM = typeof USER_FORM_MAP[keyof typeof USER_FORM_MAP];\r\nexport type USER_SEX = typeof USER_SEX_MAP[keyof typeof USER_SEX_MAP];\r\n\r\n// User interface\r\nexport interface User {\r\n id: string;\r\n name: string;\r\n userType: USER_TYPE;\r\n username?: string;\r\n nickname?: string;\r\n sex?: USER_SEX;\r\n headImg?: string;\r\n lastLoginTime?: string;\r\n tokenExpired?: string;\r\n deviceId?: string;\r\n status?: number;\r\n accountType?: number;\r\n enabled?: boolean;\r\n userFrom?: USER_FORM;\r\n needToReview?: boolean;\r\n socketOnline?: boolean;\r\n createTime?: string;\r\n mustChangePwd?: boolean;\r\n}","import pino from \"pino\";\r\nimport PinoPretty from \"pino-pretty\";\r\n// import koffi from 'koffi';\r\n\r\n// if (typeof window === 'undefined' && process.platform === 'win32') {\r\n// try {\r\n// const CP_UTF8 = 65001;\r\n// const kernel32 = koffi.load('Kernel32');\r\n// const setConsoleOutputCP = kernel32.func('SetConsoleOutputCP', 'bool', ['int']);\r\n// const setConsoleCP = kernel32.func('SetConsoleCP', 'bool', ['int']);\r\n// setConsoleOutputCP(CP_UTF8);\r\n// setConsoleCP(CP_UTF8);\r\n// } catch (e) {\r\n// console.log(e);\r\n// }\r\n// }\r\n\r\n// export const logger = pino({\r\n// name: process.env.APP_NAME ?? 'iBoot',\r\n// level: process.env.NODE_ENV !== 'production' ? 'debug' : 'info',\r\n// nestedKey: 'payload',\r\n// transport: {\r\n// target: 'pino-pretty',\r\n// options: {\r\n// colorize: true,\r\n// translateTime: 'SYS:yyyy-mm-dd HH:MM:ss',\r\n// ignore: 'pid,hostname',\r\n// messageFormat: '{msg}',\r\n// singleLine: true,\r\n// },\r\n// }\r\n// });\r\n\r\nconst stream = PinoPretty({\r\n colorize: true,\r\n destination: process.stdout,\r\n translateTime: 'SYS:yyyy-mm-dd HH:MM:ss',\r\n ignore: 'pid,hostname',\r\n messageFormat: '{msg}',\r\n singleLine: true,\r\n});\r\n\r\nexport const logger = pino({\r\n name: process.env.APP_NAME ?? 'iBoot',\r\n level: process.env.APP_ENV === 'production' ? 'info' : 'debug',\r\n nestedKey: 'payload'\r\n}, stream);","export const isArray = (obj: unknown) => {\r\n return (\r\n Array.isArray(obj) ||\r\n (typeof obj === \"object\" &&\r\n Object.prototype.toString.call(obj) === \"[object Array]\")\r\n );\r\n};\r\n\r\n/**\r\n * 生成指定长度的随机串\r\n * @param {Object} len\r\n */\r\nexport const randomString = (len: number) => {\r\n const l = len || 32;\r\n const $chars = \"ABCDEFGHJKMNPQRSTWXYZabcdefhijkmnprstwxyz2345678\";\r\n const maxPos = $chars.length;\r\n let pwd = \"\";\r\n for (let i = 0; i < l; i++) {\r\n pwd += $chars.charAt(Math.floor(Math.random() * maxPos));\r\n }\r\n return pwd;\r\n};\r\n\r\nexport const urlParamToJson = (urlQueryParams: string, exclude?: string[]): Record<string, string> => {\r\n const result: Record<string, string> = {};\r\n const strs = urlQueryParams.split(\"&\");\r\n strs.forEach((item) => {\r\n const arr = item.split(\"=\");\r\n if (arr[1]) {\r\n if (!exclude || exclude.indexOf(arr[0]) == -1) {\r\n result[arr[0]] = arr[1];\r\n }\r\n }\r\n });\r\n return result;\r\n};\r\n\r\nexport const urlEncode = (value: string | null | undefined): string => {\r\n if (!value || value == \"\" || value.length == 0) {\r\n return \"\";\r\n }\r\n return (\r\n encodeURIComponent(value)\r\n // .replace(/%20/g, '+')\r\n // .replace(/%2B/g, '\\\\+')\r\n .replace(/\\(/g, \"%28\")\r\n .replace(/\\)/g, \"%29\")\r\n .replace(/\\'/g, \"%27\")\r\n .replace(/\\!/g, \"%21\")\r\n .replace(/\\~/g, \"%7E\")\r\n );\r\n};\r\n\r\nexport const dateFormat = (dt: Date, fmt: string) => {\r\n const o:Record<string, number> = {\r\n \"M+\": dt.getMonth() + 1, //月份\r\n \"d+\": dt.getDate(), //日\r\n \"h+\": dt.getHours(), //小时\r\n \"m+\": dt.getMinutes(), //分\r\n \"s+\": dt.getSeconds(), //秒\r\n \"q+\": Math.floor((dt.getMonth() + 3) / 3), //季度\r\n S: dt.getMilliseconds(), //毫秒\r\n };\r\n if (/(y+)/.test(fmt)){\r\n const regx = new RegExp(/(y+)/);\r\n const value = regx.exec(fmt);\r\n let len = 0;\r\n if(value && value.length > 0){\r\n len = value[0].length;\r\n }\r\n fmt = fmt.replace(/(y+)/, dt.getFullYear() + \"\").substring(4 - len);\r\n }\r\n\r\n for (const k in o){\r\n const s:string = \"(\" + k + \")\";\r\n const regx = new RegExp(s);\r\n if(regx.test(fmt)){\r\n const value = regx.exec(fmt);\r\n let len = 0;\r\n if(value && value.length > 0){\r\n len = value[0].length;\r\n }\r\n fmt = fmt.replace(regx, len == 1 ? o[k].toString() : (\"00\" + o[k]).substring(o[k].toString().length))\r\n }\r\n }\r\n return fmt;\r\n}","import md5 from \"js-md5\";\r\nimport CryptoJS from 'crypto-js';\r\nimport { isArray, randomString, urlEncode, urlParamToJson } from \"./utils\";\r\nimport {\r\n ClientGetParams,\r\n ClientPostParams,\r\n CSRFToken,\r\n CurWebsite,\r\n HttpClientOpts,\r\n HttpHeaders,\r\n HttpToken,\r\n ResultModel,\r\n ServerRequestOptions,\r\n ICookies,\r\n IStorage\r\n} from \"./types/http\";\r\nimport { User, USER_TYPE, USER_TYPE_MAP } from \"./types/user\";\r\nimport { logger } from \"./logger\";\r\n\r\n\r\nexport const DEFAULT_LOCALE = 'zh-CN';\r\nexport const DEVICE_ID_KEY = \"_device_id_key\";\r\nexport const CURRENT_WEBSITE_KEY = \"_current_website_key\"\r\n\r\nconst _GET_ERROR = \"Get request error!\"\r\nconst _POST_ERROR = \"Post request error!\";\r\n\r\nexport const COOKIE_NAMES = {\r\n \"IBOOT_DEVICE_ID\": \"dvid\",\r\n \"IBOOT_LANG\": \"lang\",\r\n \"IBOOT_WEBSITE_ID\": \"wid\",\r\n \"IBOOT_WEBSITE_NO\": \"wno\",\r\n \"IBOOT_TOKEN\": \"token\",\r\n \"IBOOT_USER\": \"user\"\r\n}\r\n\r\nexport const HEADER_NAMES = {\r\n \"DEVICE_ID\": \"Device-Id\",\r\n \"LANG\": \"Lang\",\r\n \"WEBSITE_ID\": \"Website-Id\",\r\n \"WEBSITE_NO\": \"Website-No\",\r\n}\r\n\r\n\r\nconst getDefaultRequestHeader = (storage: Readonly<IStorage>): HttpHeaders => {\r\n if (!storage.get) {\r\n throw new Error(\"The get method of IStorage has not been implemented.\")\r\n }\r\n const devideId = storage.get(DEVICE_ID_KEY) ?? ''\r\n const json = storage.get(CURRENT_WEBSITE_KEY);\r\n const curWebsite: CurWebsite | null = json != null ? JSON.parse(json) : null;\r\n const header: HttpHeaders = {}\r\n if (devideId.length > 0) {\r\n header['Device-Id'] = devideId\r\n }\r\n if (curWebsite) {\r\n header['Lang'] = curWebsite.language;\r\n if (curWebsite.websiteId) {\r\n header['Website-Id'] = curWebsite.websiteId;\r\n }\r\n if (curWebsite.websiteNo) {\r\n header['Website-No'] = curWebsite.websiteNo\r\n }\r\n }\r\n return header;\r\n};\r\n\r\n\r\nexport const setDefaultRequestHeader = ({ deviceId, website }: Readonly<{ deviceId: string, website?: CurWebsite }>, storage: IStorage): void => {\r\n if (!storage.set) {\r\n throw new Error(\"The set method of IStorage has not been implemented.\")\r\n }\r\n storage.set(DEVICE_ID_KEY, deviceId);\r\n if (website) {\r\n storage.set(CURRENT_WEBSITE_KEY, JSON.stringify(website));\r\n }\r\n}\r\n\r\nexport const get = async <T>(url: string, opts?: ClientGetParams): Promise<ResultModel<T>> => {\r\n if (opts?.data) {\r\n const params = new URLSearchParams(opts.data);\r\n if (url.indexOf(\"?\") != -1) {\r\n url += `&${params}`\r\n } else {\r\n url += `?${params}`\r\n }\r\n }\r\n const headers: Record<string, string> = (opts && opts.storage && opts.storage.get) ? getDefaultRequestHeader(opts.storage) : {}\r\n const heads = opts?.headers;\r\n if (heads) {\r\n for (const field in heads) {\r\n const value = heads[field];\r\n if (value) {\r\n headers[field] = value;\r\n }\r\n }\r\n }\r\n logger.info({\r\n \"url\": url,\r\n \"headers\": headers,\r\n }, \"GET\")\r\n const res = await fetch(url, {\r\n method: 'GET',\r\n headers: headers,\r\n cache: opts?.useCache ? 'force-cache' : 'default'\r\n });\r\n\r\n if (res.ok) {\r\n const headersMap = Object.fromEntries(res.headers.entries());\r\n const result = { ...await res.json(), headers: headersMap };\r\n logger.debug(result, \"GET_RESULT\")\r\n return result\r\n }\r\n const msg = {\r\n code: res.status,\r\n success: false,\r\n msg: res.statusText\r\n }\r\n logger.error(msg);\r\n return msg;\r\n}\r\n\r\nexport const post = async <T>(url: string, opts?: ClientPostParams): Promise<ResultModel<T>> => {\r\n const data = opts?.data ?? {};\r\n const heads = opts?.headers;\r\n let body: string | FormData;\r\n const defaultHeads = (opts && opts.storage && opts.storage.get) ? getDefaultRequestHeader(opts.storage) : {}\r\n const proxyHeaders = new Headers(defaultHeads);\r\n if (!(data instanceof FormData)) {\r\n body = JSON.stringify(data);\r\n proxyHeaders.set('Content-Type', 'application/json');\r\n } else {\r\n body = data;\r\n }\r\n if (heads) {\r\n for (let field in heads) {\r\n const value = heads[field];\r\n if (value) {\r\n proxyHeaders.set(field, value);\r\n }\r\n }\r\n }\r\n logger.info({\r\n \"url\": url,\r\n \"headers\": proxyHeaders,\r\n }, \"POST\")\r\n const res = await fetch(url, {\r\n method: 'POST',\r\n headers: proxyHeaders,\r\n body: body,\r\n });\r\n if (res.ok) {\r\n const headersMap = Object.fromEntries(res.headers.entries());\r\n const result = { ...await res.json(), headers: headersMap };\r\n logger.debug(result, \"POST_RESULT\")\r\n return result\r\n }\r\n const msg = {\r\n code: res.status,\r\n success: false,\r\n msg: res.statusText,\r\n }\r\n logger.error(msg);\r\n return msg;\r\n}\r\n\r\nexport const iGet = async <T>(url: string, opts?: ClientGetParams): Promise<T | undefined> => {\r\n const res = await get<T>(url, opts);\r\n if (res.success) {\r\n return res.data as T;\r\n }\r\n if (opts?.showError) {\r\n opts.showError(res.msg ?? _GET_ERROR);\r\n return;\r\n }\r\n throw Error(res.msg ?? _GET_ERROR)\r\n}\r\n\r\nexport const iPost = async <T>(url: string, opts?: ClientPostParams): Promise<T | undefined> => {\r\n const res = await post<T>(url, opts);\r\n if (res.success) {\r\n return res.data;\r\n }\r\n if (opts?.showError) {\r\n opts.showError(res.msg ?? _POST_ERROR);\r\n return;\r\n }\r\n throw Error(res.msg ?? _POST_ERROR)\r\n}\r\n\r\nexport const iPostSuccess = async (url: string, opts?: ClientPostParams): Promise<boolean> => {\r\n const res = await post(url, opts);\r\n if (res.success) {\r\n if (opts?.showSuccess) {\r\n opts.showSuccess(res.msg ?? 'SUCCESS')\r\n }\r\n return true;\r\n }\r\n if (opts?.showError) {\r\n opts.showError(res.msg ?? _POST_ERROR);\r\n }\r\n return false;\r\n}\r\n\r\nexport const getHttpOpts = (storage: IStorage): HttpClientOpts => {\r\n if (storage.get) {\r\n const deviceId = storage.get(HEADER_NAMES.DEVICE_ID);\r\n const lang = storage.get(HEADER_NAMES.LANG);\r\n const websiteId = storage.get(HEADER_NAMES.WEBSITE_ID);\r\n const websiteNo = storage.get(HEADER_NAMES.WEBSITE_NO);\r\n const result: HttpClientOpts = {}\r\n if (deviceId && deviceId.length > 0) {\r\n result.deviceId = deviceId;\r\n }\r\n if (lang && lang.length > 0) {\r\n result.lang = lang\r\n }\r\n if (websiteId && websiteId.length > 0) {\r\n result.websiteId = websiteId\r\n }\r\n if (websiteNo && websiteNo.length > 0) {\r\n result.websiteNo = websiteNo\r\n }\r\n return result;\r\n }\r\n throw new Error(\"The set method of IStorage has not been implemented.\")\r\n}\r\n\r\nexport const getLoginUser = (cookies: ICookies): User | undefined => {\r\n if (cookies.get) {\r\n const userjson = cookies.get(COOKIE_NAMES.IBOOT_USER)\r\n if (userjson && userjson.length > 0) {\r\n return JSON.parse(userjson);\r\n }\r\n }\r\n return undefined\r\n}\r\n\r\nexport const getToken = (cookies: ICookies): HttpToken | undefined => {\r\n if (cookies.get) {\r\n const userjson = cookies.get(COOKIE_NAMES.IBOOT_USER);\r\n if (userjson && userjson.length > 0) {\r\n const user = JSON.parse(userjson);\r\n const username = user.username;\r\n const utype = user.userType.toString();\r\n const token = cookies.get(COOKIE_NAMES.IBOOT_TOKEN);\r\n if (token) {\r\n return {\r\n \"username\": username,\r\n \"utype\": utype,\r\n \"token\": token\r\n }\r\n }\r\n }\r\n }\r\n return undefined\r\n}\r\n\r\nexport const setToken = (data: User & { token: string }, cookies: ICookies): void => {\r\n const { id, name, username, nickname, headImg, token, lastLoginTime, deviceId, userType, mustChangePwd } = data;\r\n const loginUser: User = {\r\n id: id,\r\n name: name,\r\n username: username,\r\n nickname: nickname || name,\r\n headImg: headImg,\r\n lastLoginTime: lastLoginTime,\r\n deviceId: deviceId,\r\n userType: userType,\r\n accountType: 0,\r\n needToReview: false,\r\n socketOnline: false,\r\n mustChangePwd: mustChangePwd\r\n };\r\n if (!cookies.set) {\r\n throw new Error('cookies set function is undefined')\r\n }\r\n cookies.set(COOKIE_NAMES.IBOOT_TOKEN, token, {\r\n path: '/',\r\n secure: process.env.APP_ENV === 'production',\r\n httpOnly: true,\r\n sameSite: 'strict'\r\n });\r\n cookies.set(COOKIE_NAMES.IBOOT_USER, JSON.stringify(loginUser))\r\n}\r\n\r\nexport const cleanToken = (cookies: ICookies): void => {\r\n if (!cookies.set) {\r\n throw new Error('cookies set function is undefined')\r\n }\r\n cookies.set(COOKIE_NAMES.IBOOT_TOKEN, '', {\r\n maxAge: -1, //设置为 -1表示立即过期\r\n httpOnly: true,\r\n path: '/',\r\n });\r\n cookies.set(COOKIE_NAMES.IBOOT_USER, '', {\r\n maxAge: -1, //设置为 -1表示立即过期\r\n httpOnly: true,\r\n path: '/',\r\n });\r\n if (!cookies.delete) {\r\n throw new Error('cookies delete function is undefined')\r\n }\r\n cookies.delete(COOKIE_NAMES.IBOOT_TOKEN);\r\n cookies.delete(COOKIE_NAMES.IBOOT_USER);\r\n}\r\n\r\nexport class HttpClient {\r\n private readonly baseUrl: string;\r\n private readonly helloMethod: string;\r\n private readonly apiKey: string;\r\n private readonly userType: USER_TYPE;\r\n private readonly userFrom: string;\r\n private readonly deviceId: string;\r\n private readonly version: string = '1';\r\n private readonly lang: string;\r\n private readonly websiteId?: string;\r\n private readonly websiteNo?: string;\r\n constructor(opts: Readonly<HttpClientOpts>) {\r\n const isProduction = process.env.APP_ENV === 'production';\r\n if (!isProduction) {\r\n logger.warn(\"This is currently a development environment!\")\r\n }\r\n this.baseUrl = process.env.APP_BASEURL!;\r\n this.apiKey = process.env.APP_APIKEY!;\r\n this.userFrom = process.env.APP_USERFROM ?? '1';\r\n\r\n this.helloMethod = opts.helloURL ?? ''\r\n this.userType = opts.userType ?? USER_TYPE_MAP.TYPE_MGT;\r\n this.deviceId = opts.deviceId ?? randomString(10);\r\n this.lang = opts.lang ?? DEFAULT_LOCALE;\r\n this.websiteId = opts.websiteId\r\n this.websiteNo = opts.websiteNo\r\n }\r\n\r\n encrypt(data: string) {\r\n const key = CryptoJS.enc.Utf8.parse(this.apiKey);\r\n return CryptoJS.AES.encrypt(data, key).toString();\r\n }\r\n\r\n decrypt(data: string) {\r\n const key = CryptoJS.enc.Utf8.parse(this.apiKey);\r\n return CryptoJS.AES.decrypt(data, key, {\r\n mode: CryptoJS.mode.ECB,\r\n }).toString(CryptoJS.enc.Utf8);\r\n }\r\n\r\n //eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n private convertUrlParameter(data: Record<string, any>): string {\r\n const p: string[] = [];\r\n for (const o in data) {\r\n let v = data[o];\r\n if (v && typeof v === \"string\") {\r\n v = v.trim();\r\n } else if (v && typeof v === \"object\") {\r\n if (isArray(v)) {\r\n if (v.length === 0) {\r\n continue;\r\n }\r\n for (let i = 0; i < v.length; i++) {\r\n const arr_item = v[i];\r\n for (const item_field in arr_item) {\r\n const item_field_value = arr_item[item_field] ?? undefined;\r\n if (item_field_value) {\r\n if (typeof item_field_value === \"object\") {\r\n if (isArray(item_field_value)) {\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n item_field_value.forEach((item1: any, index: number) => {\r\n if (item1) {\r\n for (const f in item1) {\r\n const v = item1[f];\r\n if (v && v.toString().length > 0) {\r\n const s = `[${i.toString()}].${item_field + `[${index.toString()}].${f}`}=${urlEncode(v)}`;\r\n p.push(o + s);\r\n }\r\n }\r\n }\r\n });\r\n }\r\n } else if (item_field_value.toString().length > 0) {\r\n const s = `[${i.toString()}].${item_field}=${urlEncode(item_field_value.toString())}`;\r\n p.push(o + s);\r\n }\r\n }\r\n }\r\n }\r\n } else {\r\n for (const obj in v) {\r\n const oValue = v[obj];\r\n if (oValue != null && oValue != \"\" && oValue.length != 0) {\r\n const s = `.${obj}=${urlEncode(oValue)}`;\r\n p.push(o + s);\r\n }\r\n }\r\n }\r\n continue;\r\n } else if (v && typeof v === \"function\") {\r\n v = null;\r\n }\r\n\r\n if (v != null && v != \"\" && v.length != 0) {\r\n p.push(o + \"=\" + urlEncode(v));\r\n }\r\n }\r\n return (p && p.join(\"&\"));\r\n }\r\n\r\n private async sign(data: Record<string, object | string>): Promise<string> {\r\n //由后台分配\r\n const _apiKey = \"&key=\" + (await this.helloIboot());\r\n const arr: string[] = [];\r\n for (const o in data) {\r\n arr.push(o);\r\n }\r\n arr.sort((a: string, b: string) => {\r\n return a.toLowerCase().localeCompare(b.toLowerCase());\r\n });\r\n const res: string[] = [];\r\n arr.forEach((v: string) => {\r\n let value: object | string = data[v];\r\n if (typeof value === \"object\") {\r\n value = JSON.stringify(value);\r\n }\r\n res.push(v + \"=\" + value);\r\n });\r\n const paramsStr: string = res.join(\"&\");\r\n const str = md5.md5((paramsStr + _apiKey).toLocaleUpperCase());\r\n const logInfo = {\r\n params: paramsStr,\r\n md5: str\r\n }\r\n logger.debug(logInfo, \"API_SIGN\")\r\n return str;\r\n }\r\n\r\n //eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n private assemblyParameter(data?: Record<string, any>, username?: string): Record<string, any> {\r\n const params = data ?? {};\r\n params['timestamp'] = Date.now() + '';\r\n params['echostr'] = randomString(10);\r\n params['version'] = this.version;\r\n params['deviceId'] = this.deviceId;\r\n params['webid'] = this.websiteId;\r\n params['apiKey'] = this.apiKey;\r\n if (username && username.length > 0) {\r\n params['username'] = username;\r\n }\r\n return params;\r\n }\r\n\r\n private async assemblyHeader({ urlParams, token }: Readonly<{ urlParams: string, token?: Readonly<HttpToken> }>) {\r\n const h: Record<string, string> = {\r\n 'Content-Type': 'application/x-www-form-urlencoded',\r\n 'Res-Type': 'json',\r\n 'Device-Id': this.deviceId,\r\n 'User-Type': token?.utype.toString() ?? this.userType.toString(),\r\n 'User-From': this.userFrom,\r\n 'Api-Key': this.apiKey\r\n }\r\n if (this.lang && this.lang.length > 0) {\r\n h['Lang'] = this.lang\r\n }\r\n if (this.websiteId && this.websiteId.length > 0) {\r\n h['Web-Id'] = this.websiteId\r\n }\r\n if (this.websiteNo && this.websiteNo.length > 0) {\r\n h['Web-No'] = this.websiteNo\r\n }\r\n if (token) {\r\n if (token.token && token.token.length > 0 && token.username && token.username.length > 0) {\r\n h['Authorization'] = token.token;\r\n h['Username'] = token.username;\r\n }\r\n if (token.xcsrf) {\r\n h[token.xcsrf.csrfHeader] = token.xcsrf.csrfToken;\r\n }\r\n }\r\n const data = urlParamToJson(urlParams);\r\n const sign = await this.sign(data);\r\n h['Sign'] = sign\r\n return h;\r\n }\r\n\r\n private async helloIboot(): Promise<string> {\r\n if (this.helloMethod.length <= 0) {\r\n return this.apiKey;\r\n }\r\n const api = this.getApiUrl(this.helloMethod);\r\n const h = {\r\n 'Content-Type': 'application/x-www-form-urlencoded',\r\n 'Res-Type': 'json',\r\n 'Api-Key': this.apiKey\r\n }\r\n const logInfo = {\r\n \"url\": api,\r\n \"headers\": h\r\n }\r\n logger.debug(logInfo, \"HELLO\");\r\n const res = await fetch(api, {\r\n method: 'GET',\r\n headers: h,\r\n credentials: 'include',\r\n cache: 'force-cache'\r\n });\r\n if (res.ok) {\r\n const result = await res.json();\r\n logger.debug(result.data, 'HELLO RESULT')\r\n return result.data;\r\n }\r\n throw new Error('hello iBoot error!')\r\n }\r\n\r\n private getApiUrl(url: string): string {\r\n return `${this.baseUrl}/${url}`;\r\n }\r\n\r\n async csrf(): Promise<string | undefined> {\r\n const res = await this.get<CSRFToken>({\r\n url: 'guest/csrf'\r\n });\r\n if (res.success) {\r\n const data = res.data;\r\n if (data) {\r\n return data[\"csrfToken\"].toString();\r\n }\r\n }\r\n return undefined;\r\n }\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n async get<T>({ url, data, token, cache = 'default' }: Readonly<ServerRequestOptions>): Promise<ResultModel<T>> {\r\n const params = this.assemblyParameter(data);\r\n const urlParams = this.convertUrlParameter(params);\r\n const headers = await this.assemblyHeader({ \"urlParams\": urlParams, \"token\": token });\r\n const api = `${this.getApiUrl(url)}?${urlParams.toString()}`\r\n const logInfo = {\r\n \"url\": api,\r\n \"headers\": headers\r\n }\r\n logger.info(logInfo, \"GET\");\r\n const res = await fetch(api, {\r\n \"method\": 'GET',\r\n \"headers\": headers,\r\n \"credentials\": 'include',\r\n \"cache\": cache\r\n });\r\n if (res.ok) {\r\n const headersMap = Object.fromEntries(res.headers.entries());\r\n const result = { ...await res.json(), headers: headersMap };\r\n logger.debug(result, \"GET_RESULT\")\r\n return result;\r\n }\r\n const msg = {\r\n code: res.status,\r\n success: false,\r\n msg: res.statusText\r\n }\r\n logger.error(msg);\r\n return msg;\r\n }\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n async post<T>({ url, data, token, cache = \"default\" }: Readonly<ServerRequestOptions>): Promise<ResultModel<T>> {\r\n data = data ? { ...data } : {}\r\n const buffer = data.buffer ?? undefined;\r\n const boundary = data.boundary ?? undefined;\r\n if (buffer) {\r\n delete data.buffer;\r\n }\r\n if (boundary) {\r\n delete data.boundary;\r\n }\r\n const params = this.assemblyParameter(data);\r\n const urlParams = this.convertUrlParameter(params);\r\n const headers = await this.assemblyHeader({ \"urlParams\": urlParams, \"token\": token });\r\n if (buffer && boundary) {\r\n headers['Content-Type'] = `multipart/form-data; boundary=${boundary}`;\r\n }\r\n const api = this.getApiUrl(url);\r\n const logInfo = {\r\n \"url\": api,\r\n \"headers\": headers,\r\n \"params\": params\r\n }\r\n logger.info(logInfo, \"POST\");\r\n const urls = buffer ? `${api}?${urlParams}` : api;\r\n const res = await fetch(urls, {\r\n \"method\": 'POST',\r\n \"headers\": headers,\r\n \"body\": buffer ? buffer : urlParams.toString(),\r\n \"credentials\": 'include',\r\n \"cache\": cache\r\n });\r\n if (res.ok) {\r\n const headersMap = Object.fromEntries(res.headers.entries());\r\n const result = { ...await res.json(), headers: headersMap };\r\n logger.debug(result, \"POST_RESULT\");\r\n return result;\r\n }\r\n const msg = {\r\n code: res.status,\r\n success: false,\r\n msg: res.statusText\r\n }\r\n logger.error(msg);\r\n return msg;\r\n }\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n async stream({ url, data, token }: Readonly<Omit<ServerRequestOptions, 'cache'>>): Promise<Response> {\r\n data = data ? { ...data } : {}\r\n const buffer = data.buffer ?? undefined;\r\n const boundary = data.boundary ?? undefined;\r\n if (buffer) {\r\n delete data.buffer;\r\n }\r\n if (boundary) {\r\n delete data.boundary;\r\n }\r\n const params = this.assemblyParameter(data);\r\n const urlParams = this.convertUrlParameter(params); //new URLSearchParams(params);\r\n\r\n const headers = await this.assemblyHeader({ \"urlParams\": urlParams, \"token\": token });\r\n if (buffer && boundary) {\r\n headers['Content-Type'] = `multipart/form-data; boundary=${boundary}`;\r\n }\r\n headers['Connection'] = 'keep-alive';\r\n headers['X-Accel-Buffering'] = 'no'; //防止 Nginx 缓存\r\n headers['Cache-Control'] = 'no-cache';\r\n const api = this.getApiUrl(url)\r\n try {\r\n const url = buffer ? `${api}?${urlParams}` : api;\r\n const logInfo = {\r\n \"url\": api,\r\n \"headers\": headers,\r\n \"params\": params\r\n }\r\n logger.info(logInfo, \"STREAM\");\r\n const res = await fetch(url, {\r\n method: 'POST',\r\n headers: headers,\r\n body: buffer ? buffer : urlParams.toString(),\r\n credentials: 'include'\r\n });\r\n\r\n if (!res.ok) {\r\n throw new Error(`HTTP error! status: ${res.status}`);\r\n }\r\n if (!res.body) {\r\n throw new Error('No response body');\r\n }\r\n const headersMap = Object.fromEntries(res.headers.entries());\r\n return new Response(res.body, {\r\n headers: headersMap\r\n });\r\n } catch (e) {\r\n throw e;\r\n }\r\n }\r\n}"],"names":["ACCOUNT_TYPE_MAP","USER_TYPE_MAP","USER_FORM_MAP","USER_SEX_MAP","stream","PinoPretty","logger","pino","isArray","obj","randomString","len","l","$chars","maxPos","pwd","i","urlParamToJson","urlQueryParams","exclude","result","item","arr","urlEncode","value","dateFormat","dt","fmt","o","k","regx","DEFAULT_LOCALE","DEVICE_ID_KEY","CURRENT_WEBSITE_KEY","_GET_ERROR","_POST_ERROR","COOKIE_NAMES","HEADER_NAMES","getDefaultRequestHeader","storage","devideId","json","curWebsite","header","setDefaultRequestHeader","deviceId","website","get","url","opts","params","headers","heads","field","res","headersMap","msg","post","data","body","defaultHeads","proxyHeaders","iGet","iPost","iPostSuccess","getHttpOpts","lang","websiteId","websiteNo","getLoginUser","cookies","userjson","getToken","user","username","utype","token","setToken","id","name","nickname","headImg","lastLoginTime","userType","mustChangePwd","loginUser","cleanToken","HttpClient","key","CryptoJS","p","v","arr_item","item_field","item_field_value","item1","index","f","s","oValue","_apiKey","a","b","paramsStr","str","md5","logInfo","urlParams","h","sign","api","cache","buffer","boundary","urls","e"],"mappings":"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"}
@@ -11,6 +11,12 @@ export declare const COOKIE_NAMES: {
11
11
  IBOOT_TOKEN: string;
12
12
  IBOOT_USER: string;
13
13
  };
14
+ export declare const HEADER_NAMES: {
15
+ DEVICE_ID: string;
16
+ LANG: string;
17
+ WEBSITE_ID: string;
18
+ WEBSITE_NO: string;
19
+ };
14
20
  export declare const setDefaultRequestHeader: ({ deviceId, website }: Readonly<{
15
21
  deviceId: string;
16
22
  website?: CurWebsite;
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "iboot-http-client",
3
3
  "private": false,
4
- "version": "1.2.2",
4
+ "version": "1.2.3",
5
5
  "description": "iBoot.xin 相关应用的客户端Http封装",
6
6
  "type": "module",
7
7
  "main": "./dist/iboot-http-client.cjs.js",