From c7aece35a62b6e91fd98a625bf0e53f64bfbd18d Mon Sep 17 00:00:00 2001
From: king <18310653075@163.com>
Date: 星期四, 17 八月 2023 16:22:15 +0800
Subject: [PATCH] 2023-08-17

---
 src/api/index.js | 1142 +++++++++++++++++++++++++++++++++++++++++---------------
 1 files changed, 832 insertions(+), 310 deletions(-)

diff --git a/src/api/index.js b/src/api/index.js
index 76b3ce9..abcfa0b 100644
--- a/src/api/index.js
+++ b/src/api/index.js
@@ -1,64 +1,82 @@
 import axios from 'axios'
 import qs from 'qs'
-import {notification } from 'antd'
+import { notification, Modal } from 'antd'
 import md5 from 'md5'
+import CryptoJS from 'crypto-js'
+import jsSHA from 'jssha'
+import moment from 'moment'
+
 import Utils from '@/utils/utils.js'
-import options from '@/store/options.js'
+import CacheUtils from './cacheutils'
+
+window.GLOB.IndexDB = null
+window.GLOB.OuterToken = {}
+window.GLOB.$error = false
+
+let service = window.GLOB.service ? '-' + window.GLOB.service.replace('/', '') : ''
+let db = `mkdb${service}`
+
+if (window.indexedDB) {
+  CacheUtils.openIndexDB(db)
+}
 
 axios.defaults.crossDomain = true
 axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded;charset=UTF-8'
-axios.defaults.withCredentials = true
-
-axios.interceptors.request.use((config) => {
-  config.method = 'post'
-  if (config.url.includes('LoginAndRedirect') || config.url.includes('getjsonresult')) {
-    config.data = qs.stringify(config.data)
-  } else if (config.url.includes('Upload') || config.url.includes('doupload')) {
-    config.headers = { 'Content-Type': 'multipart/form-data' }
-  } else {
-    // config.headers.token = sessionStorage.getItem('TOKEN') || ''
-    config.data = JSON.stringify(config.data)
-  }
-
-  return config
-}, (error) => {
-  return Promise.reject(error)
-})
-
-const setCurrentUrl = () => {
-  if (!!(window.history && window.history.pushState)) {
-    sessionStorage.clear()
-    window.history.replaceState(null, null, window.location.href.split('#')[0] + '#/login')
-    window.location.reload()
-  }
-}
-
-window.GLOB.CacheMap = new Map()
+axios.defaults.withCredentials = false
 
 axios.interceptors.response.use((response) => {
   if (response.data.ErrCode === 'LoginError') {
-    setCurrentUrl()
+    if (window.GLOB.developing) {
+      sessionStorage.setItem('devError', 'true')
+      response.data.ErrCode = 'E'
+      return Promise.resolve(response.data)
+    } else if (response.config.url.indexOf('https://sso.mk9h.cn/webapi/dostars') > -1) {
+      return Promise.reject(response.data)
+    } else if (response.config.url.indexOf('https://epc.mk9h.cn/webapi/dostars') > -1) {
+      return Promise.reject(response.data)
+    }
+
+    if (!window.GLOB.$error) {
+      window.GLOB.$error = true
+
+      Modal.destroyAll()
+      Modal.error({
+        title: response.data.message,
+        okText: '鐭ラ亾浜�',
+        onOk: () => {
+          window.GLOB.$error = false
+          sessionStorage.clear()
+          if (!!(window.history && window.history.pushState)) {
+            window.history.replaceState(null, null, window.location.href.split('#')[0] + '#/login')
+            window.location.reload()
+          }
+        }
+      })
+    }
+
+    return Promise.reject(response.data)
   } else {
     return Promise.resolve(response.data)
   }
 }, (error) => {
-  notification.error({
-    className: 'notification-custom-error',
-    bottom: 0,
-    message: '鐘舵�佺爜-' + error.response.status + '锛岃鑱旂郴绠$悊鍛�',
-    placement: 'bottomRight',
-    duration: 15
-  })
-  return Promise.reject(error)
+  let response = error.response || ''
+
+  if (response && response.status) {
+    notification.error({
+      className: 'notification-custom-error',
+      bottom: 0,
+      message: '鐘舵�佺爜-' + response.status + '锛岃鑱旂郴绠$悊鍛�',
+      placement: 'bottomRight',
+      duration: 15
+    })
+  }
+
+  return Promise.reject(response)
 })
 
 class Api {
   constructor() {
-    if (process.env.NODE_ENV === 'production') {
-      axios.defaults.baseURL = document.location.origin + '/' + window.GLOB.service
-    } else {
-      // axios.defaults.baseURL = 'http://127.0.0.1:8888'
-    }
+    axios.defaults.baseURL = window.GLOB.baseurl
   }
   
   /**
@@ -66,11 +84,188 @@
    * @param {Object} param 鏌ヨ鍙婃彁浜ゅ弬鏁�
    */
   dostarInterface (param) {
-    param.userid = ''
+    param.userid = param.userid || ''
 
     return axios({
-      url: '/webapi/dostar',
-      data: param
+      url: `/webapi/dostar${param.func ? '/' + param.func : ''}`,
+      method: 'post',
+      data: JSON.stringify(param)
+    })
+  }
+
+  /**
+   * @description 寰俊涓氬姟璇锋眰
+   */
+  wxAccessToken (domain = '') {
+    let _url = window.GLOB.baseurl + 'wxpay/getaccesstoken'
+
+    if (domain) {
+      _url = domain + 'wxpay/getaccesstoken'
+    }
+
+    return new Promise(resolve => {
+      if (window.GLOB.accessToken.domain === domain && window.GLOB.accessToken.accessTime && (parseInt(new Date().getTime() / 1000) - window.GLOB.accessToken.accessTime < 30)) {
+        resolve(window.GLOB.accessToken)
+      } else {
+        window.GLOB.accessToken = {domain}
+        axios({
+          url: _url,
+          method: 'get'
+        }).then(res => {
+          if (res.oa_access_token || res.mini_access_token) {
+            window.GLOB.accessToken.accessTime = parseInt(new Date().getTime() / 1000)
+            window.GLOB.accessToken.oa_access_token = res.oa_access_token
+            window.GLOB.accessToken.mini_access_token = res.mini_access_token
+          }
+          resolve(res)
+        })
+      }
+    })
+  }
+
+  /**
+   * @description 寰俊涓氬姟璇锋眰
+   */
+  wxNginxRequest (url, method, param) {
+    let _url = url
+
+    if (!/^http/.test(url)) {
+      _url = window.GLOB.location + '/' + url
+      if (process.env.NODE_ENV === 'production') {
+        _url = document.location.origin + '/' + url
+      }
+      if (/^http:\/\/(qingqiumarket.cn|cloud.mk9h.cn|sso.mk9h.cn)/.test(_url)) {
+        _url = window.GLOB.location + ':8080/' + url
+        if (process.env.NODE_ENV === 'production') {
+          _url = document.location.origin + ':8080/' + url
+        }
+      } else if (/^https:\/\/(qingqiumarket.cn|cloud.mk9h.cn|sso.mk9h.cn)/.test(_url)) {
+        _url = window.GLOB.location + ':8443/' + url
+        if (process.env.NODE_ENV === 'production') {
+          _url = document.location.origin + ':8443/' + url
+        }
+      }
+    }
+    
+    if (param) {
+      return axios({
+        url: _url,
+        method,
+        data: param
+      })
+    }
+
+    return axios({
+      url: _url,
+      method
+    })
+  }
+
+  /**
+   * @description 鐩存帴璇锋眰
+   */
+  directRequest (params) {
+    return axios(params)
+  }
+
+  /**
+   * @description 娓稿鐧诲綍
+   */
+  getTouristMsg (binding_type, appid, openid, memberid, scanId) {
+    let _SessionUid = localStorage.getItem('SessionUid')
+
+    if (!_SessionUid) { // 鎵嬪姩娓呴櫎SessionUid鏃讹紝瀹炴椂鐢熸垚
+      _SessionUid = Utils.getuuid()
+      localStorage.setItem('SessionUid', _SessionUid)
+    }
+
+    let param = {
+      func: 's_visitor_login',
+      timestamp: moment().format('YYYY-MM-DD HH:mm:ss'), 
+      SessionUid: _SessionUid,
+      TypeCharOne: 'pc',
+      kei_id: window.btoa(window.encodeURIComponent(window.GLOB.host)),
+      appkey: window.GLOB.appkey || ''
+    }
+
+    let url = '/webapi/dologon/s_visitor_login'
+    if (window.GLOB.mainSystemApi) {
+      param.rduri = window.GLOB.mainSystemApi.replace(/\/webapi(.*)/, '/webapi/dologon/s_visitor_login')
+    }
+
+    if (binding_type === 'mk') {
+      param.binding_type = 'mk'
+      param.thd_party_member_id = memberid
+      param.thd_party_openid = openid
+      param.thd_party_appid = appid
+      param.id = scanId
+    } else if (binding_type === 'login_check') { // appid 姝ゆ椂涓虹洰鏍囧湴鍧�
+      param.v_type = 'login_check'
+      param.LoginUID = sessionStorage.getItem('LoginUID') || ''
+      
+      if (!param.rduri) {
+        param.rduri = window.GLOB.baseurl + 'webapi/dologon/s_visitor_login'
+      }
+      
+      if (appid) {
+        url = appid.replace(/\/webapi(.*)/, '/webapi/dologon/s_visitor_login')
+        param.linkurl = appid.replace(/\/webapi(.*)/, '/index.html')
+      } else {
+        param.linkurl = window.GLOB.linkurl
+      }
+    }
+    
+    param.LText = md5(window.btoa(_SessionUid + param.timestamp + (param.linkurl || '')))
+
+    // param.secretkey = md5(param.LText + 'mingke' + param.timestamp) // v_type 涓虹┖鏃�
+    let solt = md5((window.GLOB.appkey + window.btoa(window.GLOB.appkey + 'mingke') + 'mingke').toLowerCase()).slice(-6).toUpperCase()
+
+    param.v_type = param.v_type || 'Y'
+    param.secretkey = md5(param.LText + solt + param.timestamp)
+
+    return axios({
+      url: url,
+      method: 'post',
+      data: JSON.stringify(param)
+    })
+  }
+
+  /**
+   * @description 鎵嬫満鍙烽獙璇佺爜鐧诲綍
+   */
+  getphoneusermsg (phoneNo, checkcode, isCloud = false) {
+    let param = {
+      // func: 'webapi_login',
+      mob: phoneNo,
+      UserName: '',
+      Password: '',
+      check_code: checkcode,
+      way_no: 'sms_vcode',
+      systemType: window.GLOB.sysType,
+      login_city: sessionStorage.getItem('city') || '',
+      login_id_address: sessionStorage.getItem('ipAddress') || '',
+      kei_id: window.btoa(window.encodeURIComponent(window.GLOB.host)),
+      device_id: localStorage.getItem('SessionUid'),
+      appkey: window.GLOB.appkey || ''
+    }
+
+    let url = '/webapi/dologon'
+    if (isCloud) {
+      param.debug = 'Y'
+      if (window.GLOB.cloudServiceApi) {
+        param.rduri = window.GLOB.cloudServiceApi.replace(/\/webapi(.*)/, '/webapi/dologon')
+      }
+    } else if (window.GLOB.mainSystemApi) {
+      if (window.GLOB.sysType !== 'cloud' && window.GLOB.systemType !== 'production') {
+        param.linkurl = window.GLOB.linkurl
+      }
+      param.rduri = window.GLOB.mainSystemApi.replace(/\/webapi(.*)/, '/webapi/dologon')
+    }
+
+    return axios({
+      url,
+      method: 'post',
+      data: JSON.stringify(param)
     })
   }
 
@@ -78,73 +273,230 @@
    * @description 鐧诲綍绯荤粺, 鑾峰彇鐢ㄦ埛淇℃伅
    */
   getusermsg (username, password, isCloud = false) {
+    let shim = +sessionStorage.getItem('sys_time_shim')
     let param = {
       // func: 'webapi_login',
       UserName: username,
-      Password: password,
-      systemType: options.sysType,
-      Type: 'X'
+      systemType: window.GLOB.sysType,
+      Type: 'S',
+      login_city: sessionStorage.getItem('city') || '',
+      login_id_address: sessionStorage.getItem('ipAddress') || '',
+      kei_id: window.btoa(window.encodeURIComponent(window.GLOB.host)),
+      device_id: localStorage.getItem('SessionUid'),
+      timestamp: moment().add(shim, 'seconds').format('YYYY-MM-DD HH:mm:ss'),
+      appkey: window.GLOB.appkey || ''
     }
+    
+    // Type: 'S' 鏃�
+    let shaObj = new jsSHA('SHA-1', 'TEXT')
+    shaObj.update(password)
+    param.Password = shaObj.getHash('HEX').toUpperCase()
+    param.Password = md5(username + param.Password + param.timestamp)
 
-    param.Password = Utils.formatOptions(param.Password)
-    param.appkey = window.GLOB.appkey || ''
+    // Type: 'mk_' 鏃�
+    // param.Type = '鍏挜'
+    // let shaObj = new jsSHA('SHA-1', 'TEXT')
+    // shaObj.update(password)
+    // param.Password = shaObj.getHash('HEX').toUpperCase()
+    // param.Password = md5('绉侀挜' + username + param.Password + param.timestamp)
+    
+    // Type: 'X' 鏃�
+    // param.Password = Utils.formatOptions(password)
+
+    let url = '/webapi/dologon'
 
     if (isCloud) {
       param.debug = 'Y'
-      if (options.cloudServiceApi) {
-        param.rduri = options.cloudServiceApi.replace(/\/webapi(.*)/, '/webapi/dologon')
+      if (window.GLOB.cloudServiceApi) {
+        param.rduri = window.GLOB.cloudServiceApi.replace(/\/webapi(.*)/, '/webapi/dologon')
       }
-    } else if (!isCloud && window.GLOB.mainSystemApi) {
+    } else if (window.GLOB.mainSystemApi) {
+      if (window.GLOB.sysType !== 'cloud' && window.GLOB.systemType !== 'production') {
+        param.linkurl = window.GLOB.linkurl
+      }
       param.rduri = window.GLOB.mainSystemApi.replace(/\/webapi(.*)/, '/webapi/dologon')
     }
 
     return axios({
-      url: '/webapi/dologon',
-      data: param
+      url,
+      method: 'post',
+      data: JSON.stringify(param)
     })
+  }
+
+  delCacheConfig (type = '') {
+    let date = moment().subtract(7, 'days').format('YYYY-MM-DD HH:mm:ss')
+    CacheUtils.delIndexDBCacheConfig(date, type)
+  }
+
+  writeCacheConfig (menuid, data) {
+    if (!menuid) return
+    let date = moment().format('YYYY-MM-DD HH:mm:ss')
+    let _data = data ? JSON.stringify(data) : ''
+    let userid = sessionStorage.getItem('UserID') || ''
+
+    CacheUtils.writeCacheInIndexDB({menuid: md5(menuid + userid), CreateDate: date, LongParam: _data})
+  }
+
+  getLCacheConfig (menuid, minutes) {
+    return new Promise((resolve, reject) => {
+      let limit = minutes ? moment().subtract(minutes, 'minutes').format('YYYY-MM-DD HH:mm:ss') : ''
+      let userid = sessionStorage.getItem('UserID') || ''
+
+      CacheUtils.getIndexDBCacheConfig(md5(menuid + userid)).then(res => {
+        if (res && res.LongParam) {
+          resolve({data: JSON.parse(res.LongParam), valid: !limit || res.CreateDate > limit})
+        } else {
+          resolve({data: null, valid: false})
+        }
+      })
+    })
+  }
+
+  /**
+   * @description 鑾峰彇绯荤粺鐗堟湰淇℃伅
+   */
+  getAppVersion (reload) {
+    if (!window.GLOB.IndexDB) {
+      return Promise.reject()
+    }
+
+    let shim = +sessionStorage.getItem('sys_time_shim')
+    let curTime = moment().add(shim, 'seconds').format('YYYY-MM-DD HH:mm:ss') + '.000'
+
+    return new Promise((resolve, reject) => {
+      CacheUtils.getIndexDBVersion().then(msg => {
+        let param = {
+          func: 's_get_app_version',
+          modifydate: msg.createDate
+        }
+
+        param.TypeCharOne = ''
+        param.typename = ''
+
+        if (!msg.createDate && !msg.menuids) {
+          CacheUtils.updateIndexDBversion({version: '1.00', createDate: curTime})
+          resolve()
+          return
+        } else if (!msg.createDate || reload === true) {
+          param.modifydate = curTime
+          param.menuids = window.btoa(msg.menuids)
+        } else if (msg.menuids) {
+          let d = localStorage.getItem(db)
+
+          if (!d || curTime.indexOf(d) === -1) {
+            param.menuids = window.btoa(msg.menuids)
+          }
+
+          localStorage.setItem(db, curTime.substr(0, 10))
+        }
+
+        this.getSystemConfig(param).then(res => {
+          if (!res.status) {
+            reject()
+            return
+          }
+
+          let list = res.menu_data || []
+
+          if (res.menu_del) {
+            list.push(...res.menu_del)
+          }
+
+          list = list.map(mid => mid.menuid)
+
+          if (typeof(reload) === 'string' && !list.includes(reload)) {
+            list.push(reload)
+          }
+
+          if (list.length > 0) {
+            let clear = false
+            let _appkey = window.GLOB.appkey.substr(-10)
+            let reg = new RegExp(_appkey + '$', 'i')
+
+            list.forEach(mid => {
+              if (reg.test(mid)) {
+                clear = true
+              }
+            })
+            if (clear) {
+              list = ''
+            }
+            CacheUtils.delIndexDBConfig(list)
+            this.delCacheConfig('all')
+          }
+
+          CacheUtils.updateIndexDBversion({version: res.app_version || '1.00', createDate: curTime})
+
+          resolve()
+        })
+      }, () => {
+        reject()
+      })
+    })
+  }
+
+  /**
+   * @description 鏇存柊绯荤粺鐗堟湰淇℃伅锛屾竻绌洪厤缃俊鎭�
+   */
+  updateAppVersion () {
+    CacheUtils.delIndexDBConfig()
+    CacheUtils.updateIndexDBversion()
+    // CacheUtils.clearFuncs()
+  }
+
+  /**
+   * @description 鍒犻櫎鏌愪釜鑿滃崟閰嶇疆淇℃伅
+   */
+  deleteMenuStorage (menuId) {
+    CacheUtils.delIndexDBConfig(menuId)
   }
 
   /**
    * @description 鑾峰彇鎴栦慨鏀逛簯绔厤缃�
    */
   getCloudConfig (param) {
-    param.lang = localStorage.getItem('lang') || ''
-    param.appkey = window.GLOB.appkey || ''
+    param.lang = param.lang || sessionStorage.getItem('lang') || ''
+    param.appkey = param.appkey || window.GLOB.appkey || ''
+    param.SessionUid = localStorage.getItem('SessionUid') || ''
+    param.userid = param.userid || sessionStorage.getItem('CloudUserID') || ''
+    param.LoginUID = param.LoginUID || sessionStorage.getItem('CloudLoginUID') || ''
 
-    if (sessionStorage.getItem('CloudUserID') && options.cloudServiceApi) { // 瀛樺湪浜戠鐧诲綍淇℃伅锛屼笖瀛樺湪浜戠鍦板潃
-      param.rduri = options.cloudServiceApi
-      param.userid = sessionStorage.getItem('CloudUserID')
-      param.SessionUid = sessionStorage.getItem('CloudSessionUid') || ''
-      param.LoginUID = sessionStorage.getItem('CloudLoginUID') || ''
-    } else if (window.GLOB.mainSystemApi) {
-      param.rduri = window.GLOB.mainSystemApi
-      param.userid = sessionStorage.getItem('UserID')
-      param.SessionUid = sessionStorage.getItem('SessionUid') || ''
-      param.LoginUID = sessionStorage.getItem('LoginUID') || ''
-    } else {
-      param.userid = sessionStorage.getItem('UserID')
-      param.SessionUid = sessionStorage.getItem('SessionUid') || ''
-      param.LoginUID = sessionStorage.getItem('LoginUID') || ''
+    param = this.encryptParam(param)
+
+    let url = window.GLOB.cloudServiceApi ? window.GLOB.cloudServiceApi : '/webapi/dostars'
+    if (param.func) {
+      url = url + '/' + param.func
     }
 
-    param.nonc = Utils.getuuid()
-    
-    let keys = Object.keys(param).sort()
-    let values = ''
-    keys.forEach(key => {
-      if (key === 'rduri' || key === 't') return
-      if (typeof(param[key]) === 'object') {
-        values += key + JSON.stringify(param[key])
-      } else {
-        values += key + param[key]
-      }
+    return axios({
+      url,
+      method: 'post',
+      data: JSON.stringify(param)
     })
-    param.sign  = md5(values)
-    param.t = new Date().getTime()
+  }
+
+  /**
+   * @description 鑾峰彇鎴栦慨鏀圭郴缁熼厤缃紝澧炲姞appkey
+   */
+  getSystemFuncs (time) {
+    let param = {
+      func: 's_get_func_base_sso',
+      update_date: time,
+      userid: sessionStorage.getItem('UserID') || '',
+      lang: sessionStorage.getItem('lang') || '',
+      SessionUid: localStorage.getItem('SessionUid') || '',
+      LoginUID: sessionStorage.getItem('LoginUID') || '',
+      appkey: window.GLOB.appkey
+    }
+
+    let url = window.GLOB.mainSystemApi || '/webapi/dostars'
+    param = this.encryptParam(param)
 
     return axios({
-      url: `/webapi/dostars${param.func ? '/' + param.func : ''}`,
-      data: param
+      url: `${url}/${param.func}`,
+      method: 'post',
+      data: JSON.stringify(param)
     })
   }
 
@@ -152,71 +504,156 @@
    * @description 鑾峰彇鎴栦慨鏀圭郴缁熼厤缃紝澧炲姞appkey
    */
   getSystemConfig (param) {
-    param.userid = sessionStorage.getItem('UserID')
-    param.lang = localStorage.getItem('lang') || ''
-    param.SessionUid = sessionStorage.getItem('SessionUid') || ''
-    param.LoginUID = sessionStorage.getItem('LoginUID') || ''
-    param.appkey = window.GLOB.appkey || ''
+    param.userid = param.userid || sessionStorage.getItem('UserID') || ''
+    param.lang = param.lang || sessionStorage.getItem('lang') || ''
+    param.SessionUid = localStorage.getItem('SessionUid') || ''
+    param.LoginUID = param.LoginUID || sessionStorage.getItem('LoginUID') || ''
+    param.appkey = param.appkey || window.GLOB.appkey
 
-    if (sessionStorage.getItem('isEditState') === 'true' && options.cloudServiceApi) { // 缂栬緫鐘舵�侊紝涓斿瓨鍦ㄤ簯绔湴鍧�
-      param.rduri = options.cloudServiceApi
-      param.userid = sessionStorage.getItem('CloudUserID')
-      param.SessionUid = sessionStorage.getItem('CloudSessionUid') || ''
+    let url = '/webapi/dostars'
+    if (window.GLOB.mkHS && window.GLOB.cloudServiceApi) { // HS涓嬶紝涓斿瓨鍦ㄤ簯绔湴鍧�
+      url = window.GLOB.cloudServiceApi
+      param.userid = sessionStorage.getItem('CloudUserID') || ''
       param.LoginUID = sessionStorage.getItem('CloudLoginUID') || ''
     } else if (window.GLOB.mainSystemApi) {
-      param.rduri = window.GLOB.mainSystemApi
+      if (!window.GLOB.transfer) {
+        url = window.GLOB.mainSystemApi
+      } else {
+        param.rduri = window.GLOB.mainSystemApi
+      }
     }
 
-    param.nonc = Utils.getuuid()
-    
-    let keys = Object.keys(param).sort()
-    let values = ''
-    keys.forEach(key => {
-      if (key === 'rduri' || key === 't') return
-      if (typeof(param[key]) === 'object') {
-        values += key + JSON.stringify(param[key])
-      } else {
-        values += key + param[key]
-      }
-    })
-    param.sign  = md5(values)
-    param.t = new Date().getTime()
+    param = this.encryptParam(param)
 
     return axios({
-      url: `/webapi/dostars${param.func ? '/' + param.func : ''}`,
-      data: param
+      url: `${url}${param.func ? '/' + param.func : ''}`,
+      method: 'post',
+      data: JSON.stringify(param)
     })
   }
 
   /**
-   * @description 鑾峰彇鎴栦慨鏀规湰鍦伴厤缃紝澧炲姞appkey
+   * @description 鑾峰彇绯荤粺閰嶇疆锛屽彇鍊间紭鍏堢瓑绾ndexDB銆佺紦瀛樸�佹湇鍔″櫒
    */
-  getLocalConfig (param) {
-    param.userid = sessionStorage.getItem('UserID')
-    param.lang = localStorage.getItem('lang') || ''
-    param.SessionUid = sessionStorage.getItem('SessionUid') || ''
+  getCacheConfig (param) {
+    param.userid = sessionStorage.getItem('UserID') || ''
+    param.lang = param.lang || sessionStorage.getItem('lang') || ''
+    param.SessionUid = localStorage.getItem('SessionUid') || ''
+    param.LoginUID = sessionStorage.getItem('LoginUID') || ''
+    param.appkey = param.appkey || window.GLOB.appkey || ''
+
+    let url = '/webapi/dostars'
+    if (window.GLOB.mkHS) {          // HS涓嬶紝鍗曠偣鐧诲綍鏈嶅姟鍣ㄤ负浜戠
+      if (window.GLOB.cloudServiceApi) { // 瀛樺湪浜戠鍦板潃鏃讹紝浣跨敤浜戠绯荤粺鍙傛暟
+        url = window.GLOB.cloudServiceApi
+        param.userid = sessionStorage.getItem('CloudUserID') || ''
+        param.LoginUID = sessionStorage.getItem('CloudLoginUID') || ''
+      }
+    } else if (window.GLOB.mainSystemApi) {
+      if (!window.GLOB.transfer) {
+        url = window.GLOB.mainSystemApi
+      } else {
+        param.rduri = window.GLOB.mainSystemApi
+      }
+    }
+
+    let key = md5(param.MenuID + param.userid)
+    
+    if (window.GLOB.IndexDB) {
+      return new Promise(resolve => {
+        CacheUtils.getIndexDBMenuConfig(key).then(res => {
+          resolve(res)
+        }, () => {
+          param = this.encryptParam(param)
+          axios({
+            url: `${url}${param.func ? '/' + param.func : ''}`,
+            method: 'post',
+            data: JSON.stringify(param)
+          }).then(res => {
+            if (res.status && window.GLOB.IndexDB) {
+              let msg = {
+                ...res,
+                userid: param.userid,
+                menuid: param.MenuID,
+                id: key
+              }
+              CacheUtils.writeInIndexDB(msg)
+            } else if (res.status) {
+              window.GLOB.CacheMap.set(key, res)
+            }
+            resolve(res)
+          })
+        })
+      })
+    } else if (window.GLOB.CacheMap.has(key)) {
+      return Promise.resolve(window.GLOB.CacheMap.get(key))
+    } else {
+      param = this.encryptParam(param)
+
+      return new Promise(resolve => {
+        axios({
+          url: `${url}${param.func ? '/' + param.func : ''}`,
+          method: 'post',
+          data: JSON.stringify(param)
+        }).then(res => {
+          if (res.status) {
+            window.GLOB.CacheMap.set(key, res)
+          }
+          resolve(res)
+        })
+      })
+    }
+  }
+
+  /**
+   * @description 鑾峰彇鏈湴绯荤粺閰嶇疆
+   */
+  getLocalCacheConfig (param) {
+    param.userid = sessionStorage.getItem('UserID') || ''
+    param.lang = sessionStorage.getItem('lang') || ''
+    param.SessionUid = localStorage.getItem('SessionUid') || ''
     param.LoginUID = sessionStorage.getItem('LoginUID') || ''
     param.appkey = window.GLOB.appkey || ''
 
+    let _param  = md5(JSON.stringify(param))
+
+    if (window.GLOB.CacheMap.has(_param)) {
+      return Promise.resolve(window.GLOB.CacheMap.get(_param))
+    } else {
+      return Promise.resolve({ErrCode: 'S', ErrMesg: '', LongParam: '', message: '', status: false})
+    }
+  }
+
+  /**
+   * @description dostars 鍙傛暟鍔犲瘑
+   */
+  encryptParam (param) {
     param.nonc = Utils.getuuid()
-    
+      
     let keys = Object.keys(param).sort()
     let values = ''
     keys.forEach(key => {
       if (key === 'rduri' || key === 't') return
-      if (typeof(param[key]) === 'object') {
+      if (param[key] === undefined) {
+        delete param[key]
+      } else if (typeof(param[key]) === 'object') {
         values += key + JSON.stringify(param[key])
       } else {
         values += key + param[key]
       }
     })
-    param.sign  = md5(values)
-    param.t = new Date().getTime()
+    param.sign = md5(values)
+    param.t = new Date().getTime();
 
-    return axios({
-      url: `/webapi/dostars${param.func ? '/' + param.func : ''}`,
-      data: param
+    ['arr_field', 'LText_field', 'custom_script', 'LText1', 'LText', 'LText2', 'DateCount'].forEach(key => {
+      if (param[key]) {
+        let val = param[key]
+        delete param[key]
+        param[key] = val
+      }
     })
+
+    return param
   }
 
   /**
@@ -224,52 +661,39 @@
    * @param {Object}  param   璇锋眰鍙傛暟
    * @param {Boolean} SSO     鏄惁涓哄崟鐐圭櫥褰曞湴鍧�
    */
-  getSystemCacheConfig (param, SSO = true) {
-    param.userid = sessionStorage.getItem('UserID') || ''
-    param.lang = localStorage.getItem('lang') || ''
-    param.SessionUid = sessionStorage.getItem('SessionUid') || ''
-    param.LoginUID = sessionStorage.getItem('LoginUID') || ''
+  getSystemCacheConfig (param, cache = true) {
+    param.userid = param.userid || sessionStorage.getItem('UserID') || ''
+    param.lang = param.lang || sessionStorage.getItem('lang') || ''
+    param.SessionUid = localStorage.getItem('SessionUid') || ''
+    param.LoginUID = param.LoginUID || sessionStorage.getItem('LoginUID') || ''
     param.appkey = window.GLOB.appkey || ''
 
-    if (sessionStorage.getItem('isEditState') === 'true' && SSO) { // 缂栬緫鐘舵�侊紝鍗曠偣鐧诲綍鏈嶅姟鍣ㄤ负浜戠
-      if (options.cloudServiceApi) { // 瀛樺湪浜戠鍦板潃鏃讹紝浣跨敤浜戠绯荤粺鍙傛暟
-        param.rduri = options.cloudServiceApi
-        param.userid = sessionStorage.getItem('CloudUserID') || ''
-        param.SessionUid = sessionStorage.getItem('CloudSessionUid') || ''
-        param.LoginUID = sessionStorage.getItem('CloudLoginUID') || ''
-      }
-    } else if (window.GLOB.mainSystemApi && SSO) {
-      param.rduri = window.GLOB.mainSystemApi
+    let url = '/webapi/dostars'
+    if (param.rduri && !window.GLOB.transfer) {
+      url = param.rduri
+      delete param.rduri
     }
 
-    let _param = JSON.parse(JSON.stringify(param)) // 缂撳瓨鏍¢獙锛屽幓闄ゆ椂闂村拰鍔犲瘑瀛楃
-    delete _param.timestamp
-    delete _param.secretkey
-    _param = JSON.stringify(_param)
-    _param  = md5(_param)
+    let _param = ''
+    if (cache) {
+      _param = JSON.parse(JSON.stringify(param)) // 缂撳瓨鏍¢獙锛屽幓闄ゆ椂闂村拰鍔犲瘑瀛楃
+      delete _param.timestamp
+      delete _param.secretkey
+      delete _param.open_key
+      _param = JSON.stringify(_param)
+      _param  = md5(_param)
+    }
 
-    if (window.GLOB.CacheMap.has(_param)) {
+    if (cache && window.GLOB.CacheMap.has(_param)) {
       return Promise.resolve(window.GLOB.CacheMap.get(_param))
     } else {
-      param.nonc = Utils.getuuid()
-      
-      let keys = Object.keys(param).sort()
-      let values = ''
-      keys.forEach(key => {
-        if (key === 'rduri' || key === 't') return
-        if (typeof(param[key]) === 'object') {
-          values += key + JSON.stringify(param[key])
-        } else {
-          values += key + param[key]
-        }
-      })
-      param.sign  = md5(values)
-      param.t = new Date().getTime()
+      param = this.encryptParam(param)
 
       return new Promise(resolve => {
         axios({
-          url: `/webapi/dostars${param.func ? '/' + param.func : ''}`,
-          data: param
+          url: `${url}${param.func ? '/' + param.func : ''}`,
+          method: 'post',
+          data: JSON.stringify(param)
         }).then(res => {
           if (res.status) {
             window.GLOB.CacheMap.set(_param, res)
@@ -280,151 +704,240 @@
     }
   }
 
-  /**
-   * @description 鑾峰彇涓氬姟閫氱敤鎺ュ彛
-   */
-  genericInterface (param) {
-    param.userid = sessionStorage.getItem('UserID')
-    param.lang = localStorage.getItem('lang') || ''
-    param.SessionUid = sessionStorage.getItem('SessionUid') || ''
-    param.LoginUID = sessionStorage.getItem('LoginUID') || ''
-    param.appkey = window.GLOB.appkey || ''
+  visitOuterSystem (param, _resolve) {
+    let token = param.$token
+    delete param.$token
 
-    if (sessionStorage.getItem('isEditState') === 'true') { // HS涓嬭彍鍗�
-      param.userid = sessionStorage.getItem('CloudUserID')
-      param.SessionUid = sessionStorage.getItem('CloudSessionUid') || ''
-      param.LoginUID = sessionStorage.getItem('CloudLoginUID') || ''
+    try {
+      token = JSON.parse(token)
+      token = token.message
+
+      const key = CryptoJS.enc.Utf8.parse(window.GLOB.appkey.slice(-16))
+      const iv = CryptoJS.enc.Utf8.parse('mksoft')
+  
+      let encryptedHexStr = CryptoJS.enc.Hex.parse(token)
+      let _srcs = CryptoJS.enc.Base64.stringify(encryptedHexStr)
+      let decrypt = CryptoJS.AES.decrypt(_srcs, key, { iv: iv, mode: CryptoJS.mode.CBC, padding: CryptoJS.pad.Pkcs7 })
+      let decryptedStr = decrypt.toString(CryptoJS.enc.Utf8)
+      token = decryptedStr.toString()
+  
+      token = JSON.parse(window.decodeURIComponent(window.atob(token)))
+    } catch (e) {
+      token = null
+      _resolve({status: false, ErrCode: 'E', message: '鎺ュ彛淇℃伅瑙f瀽澶辫触锛�', ErrMesg: 'token_error'})
     }
 
-    param.nonc = Utils.getuuid()
-    
-    let keys = Object.keys(param).sort()
-    let values = ''
-    keys.forEach(key => {
-      if (key === 'rduri' || key === 't') return
-      if (typeof(param[key]) === 'object') {
-        values += key + JSON.stringify(param[key])
-      } else {
-        values += key + param[key]
-      }
-    })
-    param.sign  = md5(values)
-    param.t = new Date().getTime()
+    if (!token) return
 
-    return axios({
-      url: `/webapi/dostars${param.func ? '/' + param.func : ''}`,
-      data: param
-    })
+    let userid = ''
+    let loginUid = ''
+    let dataM = ''
+
+    if (window.GLOB.OuterToken[token.interface]) {
+      let msg = window.GLOB.OuterToken[token.interface]
+
+      let seconds = Math.floor((new Date().getTime() - msg.timestamp) / 1000)
+      if (seconds >= 3600) {
+        delete window.GLOB.OuterToken[token.interface]
+      } else {
+        userid = msg.userid
+        loginUid = msg.loginUid
+        dataM = msg.dataM || ''
+      }
+    }
+
+    // param.appkey = token.appkey || ''
+
+    if (userid && loginUid) {
+      param.dataM = dataM
+      param.userid = userid
+      param.LoginUID = loginUid
+      param = this.encryptParam(param)
+
+      axios({
+        url: token.interface,
+        method: 'post',
+        data: JSON.stringify(param)
+      }).then(res => {
+        _resolve(res)
+      })
+    } else {
+      let _param = {
+        UserName: token.username,
+        systemType: window.GLOB.sysType,
+        login_city: sessionStorage.getItem('city') || '',
+        device_id: token.appkey || '',
+        timestamp: moment().format('YYYY-MM-DD HH:mm:ss'),
+        Type: token.publicKey,
+        appkey: token.appkey || ''
+      }
+  
+      let shaObj = new jsSHA('SHA-1', 'TEXT')
+      shaObj.update(token.password)
+      _param.Password = shaObj.getHash('HEX').toUpperCase()
+      _param.Password = md5(token.privateKey + token.username + _param.Password + _param.timestamp)
+
+      let url = token.interface.replace(/\/webapi(.*)/, '/webapi/dologon')
+  
+      if (token.ssoInterface) {
+        _param.rduri = token.ssoInterface.replace(/\/webapi(.*)/, '/webapi/dologon')
+      }
+  
+      axios({
+        url,
+        method: 'post',
+        data: JSON.stringify(_param)
+      }).then(result => {
+        if (result.status) {
+          window.GLOB.OuterToken[token.interface] = {
+            userid: result.UserID,
+            loginUid: result.LoginUID,
+            timestamp: new Date().getTime(),
+            dataM: result.dataM ? 'Y' : ''
+          }
+
+          param.dataM = result.dataM ? 'Y' : ''
+          param.userid = result.UserID
+          param.LoginUID = result.LoginUID
+          param = this.encryptParam(param)
+
+          axios({
+            url: token.interface,
+            method: 'post',
+            data: JSON.stringify(param)
+          }).then(res => {
+            _resolve(res)
+          })
+        } else {
+          _resolve(result)
+        }
+      })
+    }
   }
 
   /**
-   * @description 瀵煎嚭Excel
+   * @description 鑾峰彇涓氬姟閫氱敤鎺ュ彛
+   * 璁块棶 'https://sso.mk9h.cn/webapi/dostars'鎴栦簯绔椂锛屼紶鍏serid銆丩oginUID
    */
-  getExcelOut (param, name) {
-    param.userid = sessionStorage.getItem('UserID')
-    param.lang = localStorage.getItem('lang') || ''
-    param.SessionUid = sessionStorage.getItem('SessionUid') || ''
-    param.LoginUID = sessionStorage.getItem('LoginUID') || ''
+  genericInterface (param) {
+    param.userid = param.userid || sessionStorage.getItem('UserID') || ''
+    param.lang = param.lang || sessionStorage.getItem('lang') || ''
+    param.SessionUid = localStorage.getItem('SessionUid') || ''
+    param.LoginUID = param.LoginUID || sessionStorage.getItem('LoginUID') || ''
     param.appkey = window.GLOB.appkey || ''
-    
-    return new Promise(resolve => {
-      axios({
-        url: '/webapi/doexcel',
-        responseType: 'blob',
-        data: param
-      }).then(res => {
 
-        try {
-          const blob = new Blob([res])
-          
-          if (res.type === 'application/json') {
-            const reader = new FileReader()
-            reader.onload = e => resolve(JSON.parse(e.target.result))
-            reader.readAsText(blob)
+    if (param.$token === '') {
+      return Promise.resolve({status: false, ErrCode: 'E', message: '鎺ュ彛鍦板潃灏氭湭璁剧疆锛�', ErrMesg: 'token_error'})
+    } else if (param.$token) {
+      return new Promise(resolve => this.visitOuterSystem(param, resolve))
+    }
+
+    if (['sPC_TableData_InUpDe', 'sPC_TableData_InUpDe_debug'].includes(param.func)) {
+      param.username = sessionStorage.getItem('User_Name') || ''
+      param.fullname = sessionStorage.getItem('Full_Name') || ''
+    }
+
+    let login = false
+    let rduri = null
+
+    if (param.rduri && /\s|\n/.test(param.rduri)) {
+      param.rduri = param.rduri.replace(/\s|\n/g, '')
+      if (!param.rduri) {
+        delete param.rduri
+      }
+    }
+
+    if (param.$login && !window.GLOB.transfer) {
+      login = true
+      rduri = param.rduri || ''
+    }
+    delete param.$login
+
+    let url = '/webapi/dostars'
+
+    if (param.rduri && !window.GLOB.transfer && /\/dostars/.test(param.rduri) && param.func !== 'webapi_ChangeUser') {
+      url = param.rduri
+      delete param.rduri
+    }
+
+    param = this.encryptParam(param)
+
+    if (login) {
+      let time = +sessionStorage.getItem(rduri)
+      let c_time = Math.round(new Date().getTime() / 1000)
+
+      if (time && c_time - time <= 60) {
+        sessionStorage.setItem(rduri, c_time)
+        return axios({
+          url: `${url}${param.func ? '/' + param.func : ''}`,
+          method: 'post',
+          data: JSON.stringify(param)
+        })
+      }
+
+      return new Promise((resolve, reject) => {
+        this.getTouristMsg('login_check', rduri).then(res => {
+          if (res.status) {
+            sessionStorage.setItem(rduri, c_time)
+            axios({
+              url: `${url}${param.func ? '/' + param.func : ''}`,
+              method: 'post',
+              data: JSON.stringify(param)
+            }).then(result => {
+              resolve(result)
+            })
           } else {
-            if ('download' in document.createElement('a')) { // 闈濱E涓嬭浇
-              const elink = document.createElement('a')
-              elink.download = name
-              elink.style.display = 'none'
-              elink.href = URL.createObjectURL(blob)
-              document.body.appendChild(elink)
-              elink.click()
-              URL.revokeObjectURL(elink.href) // 閲婃斁URL 瀵硅薄
-              document.body.removeChild(elink)
-            } else { // IE10+涓嬭浇
-              navigator.msSaveBlob(blob, name)
-            }
-            resolve()
+            resolve(res)
           }
-        } catch {
-          resolve({
-            ErrCode: 'E',
-            ErrMesg: '鏂囦欢瑙f瀽閿欒',
-            message: '',
-            status: false
-          })
-        }
+        })
       })
-    })
+    } else {
+      return axios({
+        url: `${url}${param.func ? '/' + param.func : ''}`,
+        method: 'post',
+        data: JSON.stringify(param)
+      })
+    }
   }
 
   /**
    * @description 涓婁紶base64
    * @param {String} base64 base64鍥剧墖缂栫爜
    */
-  fileuploadbase64 (base64, service = 'local') {
-    let param = {
-      func: '',
-      BasePath: 'Content/Upload',
-      lang: localStorage.getItem('lang') || '',
-      appkey: window.GLOB.appkey || '',
-      Base64Img: base64
-    }
+  fileuploadbase64 (param) {
+    param.func = ''
+    param.BasePath = 'Content/Upload'
+    param.lang = sessionStorage.getItem('lang') || ''
+    param.appkey = window.GLOB.appkey || ''
+    param.SessionUid = localStorage.getItem('SessionUid') || ''
 
-    if (service === 'sso' && window.GLOB.mainSystemApi) {
-      param.rduri = window.GLOB.mainSystemApi
-      param.userid = sessionStorage.getItem('UserID')
-      param.SessionUid = sessionStorage.getItem('SessionUid') || ''
-      param.LoginUID = sessionStorage.getItem('LoginUID') || ''
-    } else if (service === 'cloud' && options.cloudServiceApi) {
-      param.rduri = options.cloudServiceApi
-      param.userid = sessionStorage.getItem('CloudUserID')
-      param.SessionUid = sessionStorage.getItem('CloudSessionUid') || ''
-      param.LoginUID = sessionStorage.getItem('CloudLoginUID') || ''
-    } else {
-      param.userid = sessionStorage.getItem('UserID')
-      param.SessionUid = sessionStorage.getItem('SessionUid') || ''
-      param.LoginUID = sessionStorage.getItem('LoginUID') || ''
-    }
+    param.userid = param.userid || sessionStorage.getItem('UserID') || ''
+    param.LoginUID = param.LoginUID || sessionStorage.getItem('LoginUID') || ''
 
-    param.nonc = Utils.getuuid()
-    
-    let keys = Object.keys(param).sort()
-    let values = ''
-    keys.forEach(key => {
-      if (key === 'rduri' || key === 't') return
-      if (typeof(param[key]) === 'object') {
-        values += key + JSON.stringify(param[key])
-      } else {
-        values += key + param[key]
-      }
-    })
-    param.sign  = md5(values)
-    param.t = new Date().getTime()
+    param = this.encryptParam(param)
+
+    let url = '/webapi/SaveBase64Image'
 
     if (param.rduri) {
       param.rduri = param.rduri.replace(/webapi(.*)$/, 'webapi/SaveBase64Image')
-
-      return axios({
-        url: '/webapi/dostars',
-        data: param
-      })
-    } else {
-      return axios({
-        url: '/webapi/SaveBase64Image',
-        data: param
-      })
+      if (/\s|\n/.test(param.rduri)) {
+        param.rduri = param.rduri.replace(/\s|\n/g, '')
+        if (!param.rduri) {
+          delete param.rduri
+        }
+      }
     }
+
+    if (param.rduri && !window.GLOB.transfer) {
+      url = param.rduri
+      delete param.rduri
+    }
+
+    return axios({
+      url,
+      method: 'post',
+      data: JSON.stringify(param)
+    })
   }
 
   /**
@@ -433,6 +946,8 @@
   getLargeFileUpload (param) {
     return axios({
       url: '/webapi/doupload',
+      method: 'post',
+      headers: { 'Content-Type': 'multipart/form-data' },
       data: param
     })
   }
@@ -443,51 +958,58 @@
   getFilePreUpload (param) {
     return axios({
       url: '/webapi/dopreload',
+      method: 'post',
+      headers: { 'Content-Type': 'multipart/form-data' },
       data: param
     })
   }
 
   /**
-   * @description 鏂囦欢涓婁紶
+   * @description oss鏂囦欢涓婁紶
    */
-  getFileUpload (param) {
-    return axios({
-      url: '/zh-CN/Home/Upload',
-      data: param
-    })
-  }
-
-  /**
-   * @description 閫氱敤鎺ュ彛(鏁版嵁绠$悊)
-   * @param {Object} param 鏌ヨ鍙婃彁浜ゅ弬鏁�
-   */
-  commonInterface (param) {
-    param.userid = sessionStorage.getItem('UserID')
-    param.lang = localStorage.getItem('lang') || ''
-    param.SessionUid = sessionStorage.getItem('SessionUid') || ''
-    param.LoginUID = sessionStorage.getItem('LoginUID') || ''
-    param.BID = param.BID || ''
-    param.debug = param.debug || ''
+  fileOssUpload (param) {
+    let _url = window.GLOB.location + '/file/oss/upload'
+    if (process.env.NODE_ENV === 'production') {
+      _url = document.location.origin + '/file/oss/upload'
+    }
+    if (/^http:\/\/(qingqiumarket.cn|cloud.mk9h.cn|sso.mk9h.cn)/.test(_url)) {
+      _url = window.GLOB.location + ':8080/file/oss/upload'
+      if (process.env.NODE_ENV === 'production') {
+        _url = document.location.origin + ':8080/file/oss/upload'
+      }
+    } else if (/^https:\/\/(qingqiumarket.cn|cloud.mk9h.cn|sso.mk9h.cn)/.test(_url)) {
+      _url = window.GLOB.location + ':8443/file/oss/upload'
+      if (process.env.NODE_ENV === 'production') {
+        _url = document.location.origin + ':8443/file/oss/upload'
+      }
+    }
     
     return axios({
-      url: '/webapi/dostar',
+      url: _url,
+      method: 'post',
+      headers: { 'Content-Type': 'multipart/form-data' },
       data: param
     })
   }
 
   /**
-   * @description 閫氱敤鎺ュ彛(鎻愪氦)(鏁版嵁绠$悊)
-   * @param {Object} param 鏌ヨ鍙婃彁浜ゅ弬鏁�
+   * @description 鑾峰彇寰俊鏀粯浜岀淮鐮�
    */
-  submitInterface (param) {
-    param.userid = sessionStorage.getItem('UserID')
-    param.lang = localStorage.getItem('lang') || ''
-    param.SessionUid = sessionStorage.getItem('SessionUid') || ''
-    param.LoginUID = sessionStorage.getItem('LoginUID') || ''
+  getWxNativePay (param) {
+    let _url = window.GLOB.baseurl + 'wxpay/wxNativePay'
 
     return axios({
-      url: '/webapi/dostar',
-      data: param
+      url: _url,
+      method: 'post',
+      data: qs.stringify(param)
+    })
+  }
+
+  postekPrint (data) {
+    return axios({
+      url: 'http://127.0.0.1:888/postek/print',
+      method: 'post',
+      data: qs.stringify(data)
     })
   }
 }

--
Gitblit v1.8.0