732 lines
58 KiB
JavaScript
732 lines
58 KiB
JavaScript
module.exports =
|
||
/******/ (function(modules) { // webpackBootstrap
|
||
/******/ // The module cache
|
||
/******/ var installedModules = {};
|
||
/******/
|
||
/******/ // The require function
|
||
/******/ function __webpack_require__(moduleId) {
|
||
/******/
|
||
/******/ // Check if module is in cache
|
||
/******/ if(installedModules[moduleId]) {
|
||
/******/ return installedModules[moduleId].exports;
|
||
/******/ }
|
||
/******/ // Create a new module (and put it into the cache)
|
||
/******/ var module = installedModules[moduleId] = {
|
||
/******/ i: moduleId,
|
||
/******/ l: false,
|
||
/******/ exports: {}
|
||
/******/ };
|
||
/******/
|
||
/******/ // Execute the module function
|
||
/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
|
||
/******/
|
||
/******/ // Flag the module as loaded
|
||
/******/ module.l = true;
|
||
/******/
|
||
/******/ // Return the exports of the module
|
||
/******/ return module.exports;
|
||
/******/ }
|
||
/******/
|
||
/******/
|
||
/******/ // expose the modules object (__webpack_modules__)
|
||
/******/ __webpack_require__.m = modules;
|
||
/******/
|
||
/******/ // expose the module cache
|
||
/******/ __webpack_require__.c = installedModules;
|
||
/******/
|
||
/******/ // define getter function for harmony exports
|
||
/******/ __webpack_require__.d = function(exports, name, getter) {
|
||
/******/ if(!__webpack_require__.o(exports, name)) {
|
||
/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
|
||
/******/ }
|
||
/******/ };
|
||
/******/
|
||
/******/ // define __esModule on exports
|
||
/******/ __webpack_require__.r = function(exports) {
|
||
/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
|
||
/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
|
||
/******/ }
|
||
/******/ Object.defineProperty(exports, '__esModule', { value: true });
|
||
/******/ };
|
||
/******/
|
||
/******/ // create a fake namespace object
|
||
/******/ // mode & 1: value is a module id, require it
|
||
/******/ // mode & 2: merge all properties of value into the ns
|
||
/******/ // mode & 4: return value when already ns object
|
||
/******/ // mode & 8|1: behave like require
|
||
/******/ __webpack_require__.t = function(value, mode) {
|
||
/******/ if(mode & 1) value = __webpack_require__(value);
|
||
/******/ if(mode & 8) return value;
|
||
/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
|
||
/******/ var ns = Object.create(null);
|
||
/******/ __webpack_require__.r(ns);
|
||
/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
|
||
/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
|
||
/******/ return ns;
|
||
/******/ };
|
||
/******/
|
||
/******/ // getDefaultExport function for compatibility with non-harmony modules
|
||
/******/ __webpack_require__.n = function(module) {
|
||
/******/ var getter = module && module.__esModule ?
|
||
/******/ function getDefault() { return module['default']; } :
|
||
/******/ function getModuleExports() { return module; };
|
||
/******/ __webpack_require__.d(getter, 'a', getter);
|
||
/******/ return getter;
|
||
/******/ };
|
||
/******/
|
||
/******/ // Object.prototype.hasOwnProperty.call
|
||
/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
|
||
/******/
|
||
/******/ // __webpack_public_path__
|
||
/******/ __webpack_require__.p = "";
|
||
/******/
|
||
/******/
|
||
/******/ // Load entry module and return exports
|
||
/******/ return __webpack_require__(__webpack_require__.s = "./src/weRequest.js");
|
||
/******/ })
|
||
/************************************************************************/
|
||
/******/ ({
|
||
|
||
/***/ "./src/lib/flow.js":
|
||
/*!*************************!*\
|
||
!*** ./src/lib/flow.js ***!
|
||
\*************************/
|
||
/*! no static exports found */
|
||
/***/ (function(module, exports) {
|
||
|
||
var store = {};
|
||
|
||
function emit (key){
|
||
var flow = getFlow(key);
|
||
console.log("waitingList Length: " + flow.waitingList.length);
|
||
var currentLength = flow.waitingList.length;
|
||
for (var i = 0; i < currentLength; i ++) {
|
||
var callback = flow.waitingList.shift();
|
||
typeof callback == "function" && callback();
|
||
}
|
||
}
|
||
|
||
function wait (key,callback){
|
||
var flow = getFlow(key);
|
||
flow.waitingList.push(callback)
|
||
}
|
||
|
||
function getFlow(key){
|
||
if(!store[key]){
|
||
store[key] = {
|
||
waitingList:[]
|
||
}
|
||
}
|
||
|
||
return store[key];
|
||
}
|
||
|
||
module.exports = {
|
||
wait: wait,
|
||
emit: emit
|
||
}
|
||
|
||
/***/ }),
|
||
|
||
/***/ "./src/loading.js":
|
||
/*!************************!*\
|
||
!*** ./src/loading.js ***!
|
||
\************************/
|
||
/*! no static exports found */
|
||
/***/ (function(module, exports) {
|
||
|
||
function show(txt) {
|
||
wx.showToast({
|
||
title: typeof txt === 'boolean' ? '加载中' : txt,
|
||
icon: 'loading',
|
||
mask: true,
|
||
duration: 60000
|
||
})
|
||
}
|
||
|
||
function hide() {
|
||
wx.hideToast();
|
||
}
|
||
|
||
module.exports = {
|
||
show: show,
|
||
hide: hide
|
||
}
|
||
|
||
/***/ }),
|
||
|
||
/***/ "./src/weRequest.js":
|
||
/*!**************************!*\
|
||
!*** ./src/weRequest.js ***!
|
||
\**************************/
|
||
/*! no static exports found */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
const loading = __webpack_require__(/*! ./loading */ "./src/loading.js");
|
||
const flow = __webpack_require__(/*! ./lib/flow */ "./src/lib/flow.js");
|
||
|
||
//params
|
||
var sessionName = "session";
|
||
var loginTrigger = function () {
|
||
return false
|
||
};
|
||
var codeToSession = {};
|
||
var successTrigger = function () {
|
||
return true
|
||
};
|
||
var urlPerfix = "";
|
||
var successData = function (res) {
|
||
return res
|
||
};
|
||
var errorTitle = "操作失败";
|
||
var errorContent = function (res) {
|
||
return res
|
||
};
|
||
var reLoginLimit = 3;
|
||
var errorCallback = null;
|
||
var reportCGI = false;
|
||
var mockJson = false;
|
||
var globalData = false;
|
||
|
||
//global data
|
||
var session = '';
|
||
var sessionIsFresh = false;
|
||
// 正在登录中,其他请求轮询稍后,避免重复调用登录接口
|
||
var logining = false;
|
||
// 正在查询session有效期中,避免重复调用接口
|
||
var isCheckingSession = false;
|
||
|
||
function checkSession(callback, obj) {
|
||
if (isCheckingSession) {
|
||
flow.wait('checkSessionFinished', function () {
|
||
checkSession(callback, obj)
|
||
})
|
||
} else if (!sessionIsFresh && session) {
|
||
isCheckingSession = true;
|
||
obj.count++;
|
||
// 如果还没检验过session是否有效,则需要检验一次
|
||
obj._checkSessionStartTime = new Date().getTime();
|
||
|
||
console.log('wx.checkSession');
|
||
wx.checkSession({
|
||
success: function () {
|
||
// 登录态有效,且在本生命周期内无须再检验了
|
||
sessionIsFresh = true;
|
||
},
|
||
fail: function () {
|
||
// 登录态过期
|
||
session = '';
|
||
},
|
||
complete: function () {
|
||
isCheckingSession = false;
|
||
obj.count--;
|
||
obj._checkSessionEndTime = new Date().getTime();
|
||
if (typeof reportCGI === "function") {
|
||
reportCGI('wx_checkSession', obj._checkSessionStartTime, obj._checkSessionEndTime, request);
|
||
}
|
||
doLogin(callback, obj);
|
||
flow.emit('checkSessionFinished');
|
||
}
|
||
})
|
||
} else {
|
||
// 已经检验过了
|
||
doLogin(callback, obj);
|
||
}
|
||
}
|
||
|
||
function doLogin(callback, obj) {
|
||
if (session || obj.isLogin) {
|
||
// 缓存中有session,或者是登录接口
|
||
typeof callback === "function" && callback();
|
||
} else if (logining) {
|
||
// 正在登录中,请求轮询稍后,避免重复调用登录接口
|
||
flow.wait('doLoginFinished', function () {
|
||
doLogin(callback, obj);
|
||
})
|
||
} else {
|
||
// 缓存中无session
|
||
logining = true;
|
||
obj.count++;
|
||
// 记录调用wx.login前的时间戳
|
||
obj._loginStartTime = new Date().getTime();
|
||
console.log('wx.login');
|
||
wx.login({
|
||
complete: function () {
|
||
obj.count--;
|
||
// 记录wx.login返回数据后的时间戳,用于上报
|
||
obj._loginEndTime = new Date().getTime();
|
||
if (typeof reportCGI === "function") {
|
||
reportCGI('wx_login', obj._loginStartTime, obj._loginEndTime, request);
|
||
}
|
||
typeof obj.complete === "function" && obj.count == 0 && obj.complete();
|
||
},
|
||
success: function (res) {
|
||
if (res.code) {
|
||
var data;
|
||
// codeToSession.data支持函数
|
||
if (typeof codeToSession.data === "function") {
|
||
data = codeToSession.data();
|
||
} else {
|
||
data = codeToSession.data || {};
|
||
}
|
||
data[codeToSession.codeName] = res.code;
|
||
|
||
obj.count++;
|
||
requestWrapper({
|
||
url: codeToSession.url,
|
||
data: data,
|
||
method: codeToSession.method,
|
||
isLogin: true,
|
||
report: codeToSession.report || codeToSession.url,
|
||
success: function (s) {
|
||
session = s;
|
||
sessionIsFresh = true;
|
||
typeof callback === "function" && callback();
|
||
wx.setStorage({
|
||
key: sessionName,
|
||
data: session
|
||
})
|
||
},
|
||
complete: function () {
|
||
obj.count--;
|
||
typeof obj.complete === "function" && obj.count == 0 && obj.complete();
|
||
logining = false;
|
||
flow.emit('doLoginFinished');
|
||
},
|
||
fail: codeToSession.fail || null
|
||
});
|
||
} else {
|
||
fail(obj, res);
|
||
console.error(res);
|
||
// 登录失败,解除锁,防止死锁
|
||
logining = false;
|
||
flow.emit('doLoginFinished');
|
||
}
|
||
},
|
||
fail: function (res) {
|
||
fail(obj, res);
|
||
console.error(res);
|
||
// 登录失败,解除锁,防止死锁
|
||
logining = false;
|
||
flow.emit('doLoginFinished');
|
||
}
|
||
})
|
||
}
|
||
}
|
||
|
||
function preDo(obj) {
|
||
typeof obj.beforeSend === "function" && obj.beforeSend();
|
||
|
||
// 登录态失效,重复登录计数
|
||
if (typeof obj.reLoginLimit === "undefined") {
|
||
obj.reLoginLimit = 0;
|
||
} else {
|
||
obj.reLoginLimit++;
|
||
}
|
||
|
||
if (typeof obj.count === "undefined") {
|
||
obj.count = 0;
|
||
}
|
||
|
||
if (obj.showLoading) {
|
||
loading.show(obj.showLoading);
|
||
obj.complete = (function (fn) {
|
||
return function () {
|
||
loading.hide();
|
||
typeof fn === "function" && fn.apply(this, arguments);
|
||
}
|
||
})(obj.complete)
|
||
}
|
||
|
||
return obj;
|
||
}
|
||
|
||
function request(obj) {
|
||
obj.count++;
|
||
|
||
if (!obj.data) {
|
||
obj.data = {};
|
||
}
|
||
|
||
if (obj.url != codeToSession.url && session) {
|
||
obj.data[sessionName] = session;
|
||
}
|
||
|
||
// 如果有全局参数,则添加
|
||
var gd = {};
|
||
if (typeof globalData === "function") {
|
||
gd = globalData();
|
||
} else if (typeof globalData === "object") {
|
||
gd = globalData;
|
||
}
|
||
obj.data = Object.assign({}, gd, obj.data);
|
||
|
||
obj.method = obj.method || 'GET';
|
||
|
||
// 如果请求的URL中不是http开头的,则自动添加配置中的前缀
|
||
var url = obj.url.startsWith('http') ? obj.url : (urlPerfix + obj.url);
|
||
// 如果请求不是GET,则在URL中自动加上登录态和全局参数
|
||
if (obj.method != "GET") {
|
||
|
||
if (session) {
|
||
if (url.indexOf('?') >= 0) {
|
||
url += '&' + sessionName + '=' + encodeURIComponent(session);
|
||
} else {
|
||
url += '?' + sessionName + '=' + encodeURIComponent(session);
|
||
}
|
||
}
|
||
|
||
// 如果有全局参数,则在URL中添加
|
||
for (var i in gd) {
|
||
if (url.indexOf('?') >= 0) {
|
||
url += '&' + i + '=' + gd[i];
|
||
} else {
|
||
url += '?' + i + '=' + gd[i];
|
||
}
|
||
}
|
||
}
|
||
|
||
// 如果有上报字段配置,则记录请求发出前的时间戳
|
||
if (obj.report) {
|
||
obj._reportStartTime = new Date().getTime();
|
||
}
|
||
|
||
wx.request({
|
||
url: url,
|
||
data: obj.data,
|
||
method: obj.method,
|
||
header: obj.header || {},
|
||
dataType: obj.dataType || 'json',
|
||
success: function (res) {
|
||
if (res.statusCode == 200) {
|
||
|
||
// 如果有上报字段配置,则记录请求返回后的时间戳,并进行上报
|
||
if (obj.report && typeof reportCGI === "function") {
|
||
obj._reportEndTime = new Date().getTime();
|
||
reportCGI(obj.report, obj._reportStartTime, obj._reportEndTime, request);
|
||
}
|
||
|
||
if (obj.isLogin) {
|
||
// 登录请求
|
||
var s = "";
|
||
try {
|
||
s = codeToSession.success(res.data);
|
||
} catch (e) {
|
||
}
|
||
if (s) {
|
||
obj.success(s);
|
||
} else {
|
||
fail(obj, res);
|
||
}
|
||
} else if (loginTrigger(res.data) && obj.reLoginLimit < reLoginLimit) {
|
||
// 登录态失效,且重试次数不超过配置
|
||
session = '';
|
||
wx.removeStorage({
|
||
key: sessionName,
|
||
complete: function () {
|
||
doLogin(function () {
|
||
requestWrapper(obj);
|
||
}, obj)
|
||
}
|
||
})
|
||
} else if (successTrigger(res.data) && typeof obj.success === "function") {
|
||
// 接口返回成功码
|
||
var realData = null;
|
||
try {
|
||
realData = successData(res.data);
|
||
} catch (e) {
|
||
console.error("Function successData occur error: " + e);
|
||
}
|
||
if(!obj.noCacheFlash) {
|
||
// 如果为了保证页面不闪烁,则不回调,只是缓存最新数据,待下次进入再用
|
||
obj.success(realData);
|
||
}
|
||
if (obj.cache === true || (typeof obj.cache === "function" && obj.cache(realData))) {
|
||
wx.setStorage({
|
||
key: obj.url,
|
||
data: realData
|
||
})
|
||
}
|
||
} else {
|
||
// 接口返回失败码
|
||
fail(obj, res);
|
||
}
|
||
} else {
|
||
fail(obj, res);
|
||
}
|
||
},
|
||
fail: function (res) {
|
||
fail(obj, res);
|
||
console.error(res);
|
||
},
|
||
complete: function () {
|
||
obj.count--;
|
||
typeof obj.complete === "function" && obj.count == 0 && obj.complete();
|
||
}
|
||
})
|
||
}
|
||
|
||
function uploadFile(obj) {
|
||
obj.count++;
|
||
|
||
if (!obj.formData) {
|
||
obj.formData = {};
|
||
}
|
||
obj.formData[sessionName] = session;
|
||
|
||
// 如果有全局参数,则添加
|
||
var gd = {};
|
||
if (typeof globalData === "function") {
|
||
gd = globalData();
|
||
} else if (typeof globalData === "object") {
|
||
gd = globalData;
|
||
}
|
||
obj.formData = Object.assign({}, gd, obj.formData);
|
||
|
||
obj.dataType = obj.dataType || 'json';
|
||
|
||
// 如果请求的URL中不是http开头的,则自动添加配置中的前缀
|
||
var url = obj.url.startsWith('http') ? obj.url : (urlPerfix + obj.url);
|
||
|
||
// 在URL中自动加上登录态和全局参数
|
||
if (session) {
|
||
if (url.indexOf('?') >= 0) {
|
||
url += '&' + sessionName + '=' + session;
|
||
} else {
|
||
url += '?' + sessionName + '=' + session;
|
||
}
|
||
}
|
||
|
||
// 如果有全局参数,则在URL中添加
|
||
for (var i in gd) {
|
||
if (url.indexOf('?') >= 0) {
|
||
url += '&' + i + '=' + gd[i];
|
||
} else {
|
||
url += '?' + i + '=' + gd[i];
|
||
}
|
||
}
|
||
|
||
// 如果有上报字段配置,则记录请求发出前的时间戳
|
||
if (obj.report) {
|
||
obj._reportStartTime = new Date().getTime();
|
||
}
|
||
|
||
wx.uploadFile({
|
||
url: url,
|
||
filePath: obj.filePath || '',
|
||
name: obj.name || '',
|
||
formData: obj.formData,
|
||
success: function (res) {
|
||
if (res.statusCode == 200 && res.errMsg == 'uploadFile:ok') {
|
||
|
||
// 如果有上报字段配置,则记录请求返回后的时间戳,并进行上报
|
||
if (obj.report && typeof reportCGI === "function") {
|
||
obj.endTime = new Date().getTime();
|
||
reportCGI(obj.report, obj._reportStartTime, obj._reportEndTime, request);
|
||
}
|
||
|
||
if (obj.dataType == 'json') {
|
||
try {
|
||
res.data = JSON.parse(res.data);
|
||
} catch (e) {
|
||
fail(obj, res);
|
||
return false;
|
||
}
|
||
}
|
||
if (loginTrigger(res.data) && obj.reLoginLimit < reLoginLimit) {
|
||
// 登录态失效,且重试次数不超过配置
|
||
session = '';
|
||
wx.removeStorage({
|
||
key: sessionName,
|
||
complete: function () {
|
||
doLogin(function () {
|
||
uploadFileWrapper(obj);
|
||
}, obj)
|
||
}
|
||
})
|
||
} else if (successTrigger(res.data) && typeof obj.success === "function") {
|
||
// 接口返回成功码
|
||
obj.success(successData(res.data));
|
||
} else {
|
||
// 接口返回失败码
|
||
fail(obj, res);
|
||
}
|
||
} else {
|
||
fail(obj, res);
|
||
}
|
||
},
|
||
fail: function (res) {
|
||
fail(obj, res);
|
||
console.error(res);
|
||
},
|
||
complete: function () {
|
||
obj.count--;
|
||
typeof obj.complete === "function" && obj.count == 0 && obj.complete();
|
||
}
|
||
})
|
||
}
|
||
|
||
function fail(obj, res) {
|
||
if (typeof obj.fail === "function") {
|
||
obj.fail(res);
|
||
} else {
|
||
var title = "";
|
||
if (typeof errorTitle === "function") {
|
||
try {
|
||
title = errorTitle(res.data)
|
||
} catch (e) {
|
||
}
|
||
} else if (typeof errorTitle === "string") {
|
||
title = errorTitle;
|
||
}
|
||
|
||
var content = "";
|
||
if (typeof errorContent === "function") {
|
||
try {
|
||
content = errorContent(res.data)
|
||
} catch (e) {
|
||
}
|
||
} else if (typeof errorContent === "string") {
|
||
content = errorContent;
|
||
}
|
||
|
||
wx.showModal({
|
||
title: title,
|
||
content: content || "网络或服务异常,请稍后重试",
|
||
showCancel: false
|
||
})
|
||
}
|
||
|
||
// 如果有配置统一错误回调函数,则执行它
|
||
if (typeof errorCallback === "function") {
|
||
errorCallback(obj, res);
|
||
}
|
||
|
||
console.error(res);
|
||
}
|
||
|
||
function getCache(obj, callback) {
|
||
if (obj.cache) {
|
||
wx.getStorage({
|
||
key: obj.url,
|
||
success: function (res) {
|
||
typeof obj.beforeSend === "function" && obj.beforeSend();
|
||
if (typeof obj.cache === "function" && obj.cache(res.data)) {
|
||
typeof obj.success === "function" && obj.success(res.data, {isCache: true});
|
||
} else if (obj.cache == true) {
|
||
typeof obj.success === "function" && obj.success(res.data, {isCache: true});
|
||
}
|
||
typeof obj.complete === "function" && obj.complete();
|
||
// 成功取出缓存,还要去请求拿最新的再存起来
|
||
callback(obj);
|
||
},
|
||
fail: function() {
|
||
// 找不到缓存,直接发起请求,且不再防止页面闪烁(本来就没缓存了,更不存在更新页面导致的闪烁)
|
||
obj.noCacheFlash = false;
|
||
callback(obj);
|
||
}
|
||
})
|
||
} else {
|
||
callback(obj);
|
||
}
|
||
}
|
||
|
||
function login(callback) {
|
||
checkSession(callback, {})
|
||
}
|
||
|
||
function init(params) {
|
||
sessionName = params.sessionName || 'session';
|
||
loginTrigger = params.loginTrigger || function () {
|
||
return false
|
||
};
|
||
codeToSession = params.codeToSession || {};
|
||
successTrigger = params.successTrigger || function () {
|
||
return true
|
||
};
|
||
urlPerfix = params.urlPerfix || "";
|
||
successData = params.successData || function (res) {
|
||
return res
|
||
};
|
||
errorTitle = params.errorTitle || "操作失败";
|
||
errorContent = params.errorContent || false;
|
||
reLoginLimit = params.reLoginLimit || 3;
|
||
errorCallback = params.errorCallback || null;
|
||
sessionIsFresh = params.doNotCheckSession || false;
|
||
reportCGI = params.reportCGI || false;
|
||
mockJson = params.mockJson || false;
|
||
globalData = params.globalData || false;
|
||
|
||
try {
|
||
session = wx.getStorageSync(sessionName) || '';
|
||
} catch (e) {
|
||
}
|
||
}
|
||
|
||
function requestWrapper(obj) {
|
||
obj = preDo(obj);
|
||
if (mockJson && mockJson[obj.url]) {
|
||
// mock 模式
|
||
mock(obj);
|
||
} else {
|
||
getCache(obj, function (obj) {
|
||
checkSession(function () {
|
||
request(obj);
|
||
}, obj)
|
||
}
|
||
)
|
||
}
|
||
}
|
||
|
||
function uploadFileWrapper(obj) {
|
||
obj = preDo(obj);
|
||
checkSession(function () {
|
||
uploadFile(obj);
|
||
}, obj)
|
||
}
|
||
|
||
function setSession(s) {
|
||
session = s;
|
||
sessionIsFresh = true;
|
||
}
|
||
|
||
function mock(obj) {
|
||
var res = {
|
||
data: mockJson[obj.url]
|
||
};
|
||
if (successTrigger(res.data) && typeof obj.success === "function") {
|
||
// 接口返回成功码
|
||
obj.success(successData(res.data));
|
||
} else {
|
||
// 接口返回失败码
|
||
fail(obj, res);
|
||
}
|
||
if (typeof obj.complete === "function") {
|
||
obj.complete();
|
||
}
|
||
}
|
||
|
||
function getSession() {
|
||
return session;
|
||
}
|
||
|
||
function getConfig() {
|
||
return {
|
||
'urlPerfix': urlPerfix
|
||
}
|
||
}
|
||
|
||
module.exports = {
|
||
init: init,
|
||
request: requestWrapper,
|
||
uploadFile: uploadFileWrapper,
|
||
setSession: setSession,
|
||
login: login,
|
||
getSession: getSession,
|
||
getConfig: getConfig
|
||
};
|
||
|
||
/***/ })
|
||
|
||
/******/ });
|
||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://weRequest/webpack/bootstrap","webpack://weRequest/./src/lib/flow.js","webpack://weRequest/./src/loading.js","webpack://weRequest/./src/weRequest.js"],"names":[],"mappings":";;AAAA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;;AAGA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,kDAA0C,gCAAgC;AAC1E;AACA;;AAEA;AACA;AACA;AACA,gEAAwD,kBAAkB;AAC1E;AACA,yDAAiD,cAAc;AAC/D;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iDAAyC,iCAAiC;AAC1E,wHAAgH,mBAAmB,EAAE;AACrI;AACA;;AAEA;AACA;AACA;AACA,mCAA2B,0BAA0B,EAAE;AACvD,yCAAiC,eAAe;AAChD;AACA;AACA;;AAEA;AACA,8DAAsD,+DAA+D;;AAErH;AACA;;;AAGA;AACA;;;;;;;;;;;;AClFA;;AAEA;AACA;AACA;AACA;AACA,mBAAmB,mBAAmB;AACtC;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,C;;;;;;;;;;;AC9BA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,C;;;;;;;;;;;AChBA,gBAAgB,mBAAO,CAAC,mCAAW;AACnC,aAAa,mBAAO,CAAC,qCAAY;;AAEjC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,SAAS;AACT,KAAK;AACL;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,KAAK;AACL;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,SAAS;AACT,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AACzB;AACA;AACA;AACA;AACA;AACA,yBAAyB;AACzB;AACA,qBAAqB;AACrB,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,+BAA+B;;AAE/B;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,gCAAgC;AAChC;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6BAA6B;AAC7B;AACA,qBAAqB;AACrB,iBAAiB;AACjB;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yBAAyB;AACzB;AACA,iBAAiB;AACjB;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,mCAAmC;;AAEnC;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6BAA6B;AAC7B;AACA,qBAAqB;AACrB,iBAAiB;AACjB;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,aAAa;AACb;AACA,SAAS;AACT;AACA;;AAEA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA,SAAS;AACT;AACA;;AAEA;AACA;AACA;AACA;AACA,SAAS;AACT;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gFAAgF,cAAc;AAC9F,iBAAiB;AACjB,gFAAgF,cAAc;AAC9F;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,KAAK;AACL;AACA;AACA;;AAEA;AACA,6BAA6B;AAC7B;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,E","file":"weRequest.js","sourcesContent":[" \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = \"./src/weRequest.js\");\n","var store = {};\n\nfunction emit (key){\n    var flow = getFlow(key);\n    console.log(\"waitingList Length: \" + flow.waitingList.length);\n    var currentLength = flow.waitingList.length;\n    for (var i = 0; i < currentLength; i ++) {\n        var callback = flow.waitingList.shift();\n        typeof callback == \"function\" && callback();\n    }\n}\n\nfunction wait (key,callback){\n    var flow = getFlow(key);\n    flow.waitingList.push(callback)\n}\n\nfunction getFlow(key){\n    if(!store[key]){\n        store[key] = {\n            waitingList:[]\n        }\n    }\n\n    return store[key];\n}\n\nmodule.exports = {\n    wait: wait,\n    emit: emit\n}","function show(txt) {\n    wx.showToast({\n        title: typeof txt === 'boolean' ? '加载中' : txt,\n        icon: 'loading',\n        mask: true,\n        duration: 60000\n    })\n}\n\nfunction hide() {\n    wx.hideToast();\n}\n\nmodule.exports = {\n    show: show,\n    hide: hide\n}","const loading = require('./loading');\nconst flow = require('./lib/flow');\n\n//params\nvar sessionName    = \"session\";\nvar loginTrigger   = function () {\n    return false\n};\nvar codeToSession  = {};\nvar successTrigger = function () {\n    return true\n};\nvar urlPerfix      = \"\";\nvar successData    = function (res) {\n    return res\n};\nvar errorTitle     = \"操作失败\";\nvar errorContent   = function (res) {\n    return res\n};\nvar reLoginLimit   = 3;\nvar errorCallback  = null;\nvar reportCGI      = false;\nvar mockJson       = false;\nvar globalData     = false;\n\n//global data\nvar session           = '';\nvar sessionIsFresh    = false;\n// 正在登录中，其他请求轮询稍后，避免重复调用登录接口\nvar logining          = false;\n// 正在查询session有效期中，避免重复调用接口\nvar isCheckingSession = false;\n\nfunction checkSession(callback, obj) {\n    if (isCheckingSession) {\n        flow.wait('checkSessionFinished', function () {\n            checkSession(callback, obj)\n        })\n    } else if (!sessionIsFresh && session) {\n        isCheckingSession = true;\n        obj.count++;\n        // 如果还没检验过session是否有效，则需要检验一次\n        obj._checkSessionStartTime = new Date().getTime();\n\n        console.log('wx.checkSession');\n        wx.checkSession({\n            success: function () {\n                // 登录态有效，且在本生命周期内无须再检验了\n                sessionIsFresh = true;\n            },\n            fail: function () {\n                // 登录态过期\n                session = '';\n            },\n            complete: function () {\n                isCheckingSession = false;\n                obj.count--;\n                obj._checkSessionEndTime = new Date().getTime();\n                if (typeof reportCGI === \"function\") {\n                    reportCGI('wx_checkSession', obj._checkSessionStartTime, obj._checkSessionEndTime, request);\n                }\n                doLogin(callback, obj);\n                flow.emit('checkSessionFinished');\n            }\n        })\n    } else {\n        // 已经检验过了\n        doLogin(callback, obj);\n    }\n}\n\nfunction doLogin(callback, obj) {\n    if (session || obj.isLogin) {\n        // 缓存中有session，或者是登录接口\n        typeof callback === \"function\" && callback();\n    } else if (logining) {\n        // 正在登录中，请求轮询稍后，避免重复调用登录接口\n        flow.wait('doLoginFinished', function () {\n            doLogin(callback, obj);\n        })\n    } else {\n        // 缓存中无session\n        logining = true;\n        obj.count++;\n        // 记录调用wx.login前的时间戳\n        obj._loginStartTime = new Date().getTime();\n        console.log('wx.login');\n        wx.login({\n            complete: function () {\n                obj.count--;\n                // 记录wx.login返回数据后的时间戳，用于上报\n                obj._loginEndTime = new Date().getTime();\n                if (typeof reportCGI === \"function\") {\n                    reportCGI('wx_login', obj._loginStartTime, obj._loginEndTime, request);\n                }\n                typeof obj.complete === \"function\" && obj.count == 0 && obj.complete();\n            },\n            success: function (res) {\n                if (res.code) {\n                    var data;\n                    // codeToSession.data支持函数\n                    if (typeof codeToSession.data === \"function\") {\n                        data = codeToSession.data();\n                    } else {\n                        data = codeToSession.data || {};\n                    }\n                    data[codeToSession.codeName] = res.code;\n\n                    obj.count++;\n                    requestWrapper({\n                        url: codeToSession.url,\n                        data: data,\n                        method: codeToSession.method,\n                        isLogin: true,\n                        report: codeToSession.report || codeToSession.url,\n                        success: function (s) {\n                            session        = s;\n                            sessionIsFresh = true;\n                            typeof callback === \"function\" && callback();\n                            wx.setStorage({\n                                key: sessionName,\n                                data: session\n                            })\n                        },\n                        complete: function () {\n                            obj.count--;\n                            typeof obj.complete === \"function\" && obj.count == 0 && obj.complete();\n                            logining = false;\n                            flow.emit('doLoginFinished');\n                        },\n                        fail: codeToSession.fail || null\n                    });\n                } else {\n                    fail(obj, res);\n                    console.error(res);\n                    // 登录失败，解除锁，防止死锁\n                    logining = false;\n                    flow.emit('doLoginFinished');\n                }\n            },\n            fail: function (res) {\n                fail(obj, res);\n                console.error(res);\n                // 登录失败，解除锁，防止死锁\n                logining = false;\n                flow.emit('doLoginFinished');\n            }\n        })\n    }\n}\n\nfunction preDo(obj) {\n    typeof obj.beforeSend === \"function\" && obj.beforeSend();\n\n    // 登录态失效，重复登录计数\n    if (typeof obj.reLoginLimit === \"undefined\") {\n        obj.reLoginLimit = 0;\n    } else {\n        obj.reLoginLimit++;\n    }\n\n    if (typeof obj.count === \"undefined\") {\n        obj.count = 0;\n    }\n\n    if (obj.showLoading) {\n        loading.show(obj.showLoading);\n        obj.complete = (function (fn) {\n            return function () {\n                loading.hide();\n                typeof fn === \"function\" && fn.apply(this, arguments);\n            }\n        })(obj.complete)\n    }\n\n    return obj;\n}\n\nfunction request(obj) {\n    obj.count++;\n\n    if (!obj.data) {\n        obj.data = {};\n    }\n\n    if (obj.url != codeToSession.url && session) {\n        obj.data[sessionName] = session;\n    }\n\n    // 如果有全局参数，则添加\n    var gd = {};\n    if (typeof globalData === \"function\") {\n        gd = globalData();\n    } else if (typeof globalData === \"object\") {\n        gd = globalData;\n    }\n    obj.data = Object.assign({}, gd, obj.data);\n\n    obj.method = obj.method || 'GET';\n\n    // 如果请求的URL中不是http开头的，则自动添加配置中的前缀\n    var url = obj.url.startsWith('http') ? obj.url : (urlPerfix + obj.url);\n    // 如果请求不是GET，则在URL中自动加上登录态和全局参数\n    if (obj.method != \"GET\") {\n\n        if (session) {\n            if (url.indexOf('?') >= 0) {\n                url += '&' + sessionName + '=' + encodeURIComponent(session);\n            } else {\n                url += '?' + sessionName + '=' + encodeURIComponent(session);\n            }\n        }\n\n        // 如果有全局参数，则在URL中添加\n        for (var i in gd) {\n            if (url.indexOf('?') >= 0) {\n                url += '&' + i + '=' + gd[i];\n            } else {\n                url += '?' + i + '=' + gd[i];\n            }\n        }\n    }\n\n    // 如果有上报字段配置，则记录请求发出前的时间戳\n    if (obj.report) {\n        obj._reportStartTime = new Date().getTime();\n    }\n\n    wx.request({\n        url: url,\n        data: obj.data,\n        method: obj.method,\n        header: obj.header || {},\n        dataType: obj.dataType || 'json',\n        success: function (res) {\n            if (res.statusCode == 200) {\n\n                // 如果有上报字段配置，则记录请求返回后的时间戳，并进行上报\n                if (obj.report && typeof reportCGI === \"function\") {\n                    obj._reportEndTime = new Date().getTime();\n                    reportCGI(obj.report, obj._reportStartTime, obj._reportEndTime, request);\n                }\n\n                if (obj.isLogin) {\n                    // 登录请求\n                    var s = \"\";\n                    try {\n                        s = codeToSession.success(res.data);\n                    } catch (e) {\n                    }\n                    if (s) {\n                        obj.success(s);\n                    } else {\n                        fail(obj, res);\n                    }\n                } else if (loginTrigger(res.data) && obj.reLoginLimit < reLoginLimit) {\n                    // 登录态失效，且重试次数不超过配置\n                    session = '';\n                    wx.removeStorage({\n                        key: sessionName,\n                        complete: function () {\n                            doLogin(function () {\n                                requestWrapper(obj);\n                            }, obj)\n                        }\n                    })\n                } else if (successTrigger(res.data) && typeof obj.success === \"function\") {\n                    // 接口返回成功码\n                    var realData = null;\n                    try {\n                        realData = successData(res.data);\n                    } catch (e) {\n                        console.error(\"Function successData occur error: \" + e);\n                    }\n                    if(!obj.noCacheFlash) {\n                        // 如果为了保证页面不闪烁，则不回调，只是缓存最新数据，待下次进入再用\n                        obj.success(realData);\n                    }\n                    if (obj.cache === true || (typeof obj.cache === \"function\" && obj.cache(realData))) {\n                        wx.setStorage({\n                            key: obj.url,\n                            data: realData\n                        })\n                    }\n                } else {\n                    // 接口返回失败码\n                    fail(obj, res);\n                }\n            } else {\n                fail(obj, res);\n            }\n        },\n        fail: function (res) {\n            fail(obj, res);\n            console.error(res);\n        },\n        complete: function () {\n            obj.count--;\n            typeof obj.complete === \"function\" && obj.count == 0 && obj.complete();\n        }\n    })\n}\n\nfunction uploadFile(obj) {\n    obj.count++;\n\n    if (!obj.formData) {\n        obj.formData = {};\n    }\n    obj.formData[sessionName] = session;\n\n    // 如果有全局参数，则添加\n    var gd = {};\n    if (typeof globalData === \"function\") {\n        gd = globalData();\n    } else if (typeof globalData === \"object\") {\n        gd = globalData;\n    }\n    obj.formData = Object.assign({}, gd, obj.formData);\n\n    obj.dataType = obj.dataType || 'json';\n\n    // 如果请求的URL中不是http开头的，则自动添加配置中的前缀\n    var url = obj.url.startsWith('http') ? obj.url : (urlPerfix + obj.url);\n\n    // 在URL中自动加上登录态和全局参数\n    if (session) {\n        if (url.indexOf('?') >= 0) {\n            url += '&' + sessionName + '=' + session;\n        } else {\n            url += '?' + sessionName + '=' + session;\n        }\n    }\n\n    // 如果有全局参数，则在URL中添加\n    for (var i in gd) {\n        if (url.indexOf('?') >= 0) {\n            url += '&' + i + '=' + gd[i];\n        } else {\n            url += '?' + i + '=' + gd[i];\n        }\n    }\n\n    // 如果有上报字段配置，则记录请求发出前的时间戳\n    if (obj.report) {\n        obj._reportStartTime = new Date().getTime();\n    }\n\n    wx.uploadFile({\n        url: url,\n        filePath: obj.filePath || '',\n        name: obj.name || '',\n        formData: obj.formData,\n        success: function (res) {\n            if (res.statusCode == 200 && res.errMsg == 'uploadFile:ok') {\n\n                // 如果有上报字段配置，则记录请求返回后的时间戳，并进行上报\n                if (obj.report && typeof reportCGI === \"function\") {\n                    obj.endTime = new Date().getTime();\n                    reportCGI(obj.report, obj._reportStartTime, obj._reportEndTime, request);\n                }\n\n                if (obj.dataType == 'json') {\n                    try {\n                        res.data = JSON.parse(res.data);\n                    } catch (e) {\n                        fail(obj, res);\n                        return false;\n                    }\n                }\n                if (loginTrigger(res.data) && obj.reLoginLimit < reLoginLimit) {\n                    // 登录态失效，且重试次数不超过配置\n                    session = '';\n                    wx.removeStorage({\n                        key: sessionName,\n                        complete: function () {\n                            doLogin(function () {\n                                uploadFileWrapper(obj);\n                            }, obj)\n                        }\n                    })\n                } else if (successTrigger(res.data) && typeof obj.success === \"function\") {\n                    // 接口返回成功码\n                    obj.success(successData(res.data));\n                } else {\n                    // 接口返回失败码\n                    fail(obj, res);\n                }\n            } else {\n                fail(obj, res);\n            }\n        },\n        fail: function (res) {\n            fail(obj, res);\n            console.error(res);\n        },\n        complete: function () {\n            obj.count--;\n            typeof obj.complete === \"function\" && obj.count == 0 && obj.complete();\n        }\n    })\n}\n\nfunction fail(obj, res) {\n    if (typeof obj.fail === \"function\") {\n        obj.fail(res);\n    } else {\n        var title = \"\";\n        if (typeof errorTitle === \"function\") {\n            try {\n                title = errorTitle(res.data)\n            } catch (e) {\n            }\n        } else if (typeof errorTitle === \"string\") {\n            title = errorTitle;\n        }\n\n        var content = \"\";\n        if (typeof errorContent === \"function\") {\n            try {\n                content = errorContent(res.data)\n            } catch (e) {\n            }\n        } else if (typeof errorContent === \"string\") {\n            content = errorContent;\n        }\n\n        wx.showModal({\n            title: title,\n            content: content || \"网络或服务异常，请稍后重试\",\n            showCancel: false\n        })\n    }\n\n    // 如果有配置统一错误回调函数，则执行它\n    if (typeof errorCallback === \"function\") {\n        errorCallback(obj, res);\n    }\n\n    console.error(res);\n}\n\nfunction getCache(obj, callback) {\n    if (obj.cache) {\n        wx.getStorage({\n            key: obj.url,\n            success: function (res) {\n                typeof obj.beforeSend === \"function\" && obj.beforeSend();\n                if (typeof obj.cache === \"function\" && obj.cache(res.data)) {\n                    typeof obj.success === \"function\" && obj.success(res.data, {isCache: true});\n                } else if (obj.cache == true) {\n                    typeof obj.success === \"function\" && obj.success(res.data, {isCache: true});\n                }\n                typeof obj.complete === \"function\" && obj.complete();\n                // 成功取出缓存，还要去请求拿最新的再存起来\n                callback(obj);\n            },\n            fail: function() {\n                // 找不到缓存，直接发起请求，且不再防止页面闪烁（本来就没缓存了，更不存在更新页面导致的闪烁）\n                obj.noCacheFlash = false;\n                callback(obj);\n            }\n        })\n    } else {\n        callback(obj);\n    }\n}\n\nfunction login(callback) {\n    checkSession(callback, {})\n}\n\nfunction init(params) {\n    sessionName    = params.sessionName || 'session';\n    loginTrigger   = params.loginTrigger || function () {\n            return false\n        };\n    codeToSession  = params.codeToSession || {};\n    successTrigger = params.successTrigger || function () {\n            return true\n        };\n    urlPerfix      = params.urlPerfix || \"\";\n    successData    = params.successData || function (res) {\n            return res\n        };\n    errorTitle     = params.errorTitle || \"操作失败\";\n    errorContent   = params.errorContent || false;\n    reLoginLimit   = params.reLoginLimit || 3;\n    errorCallback  = params.errorCallback || null;\n    sessionIsFresh = params.doNotCheckSession || false;\n    reportCGI      = params.reportCGI || false;\n    mockJson       = params.mockJson || false;\n    globalData     = params.globalData || false;\n\n    try {\n        session = wx.getStorageSync(sessionName) || '';\n    } catch (e) {\n    }\n}\n\nfunction requestWrapper(obj) {\n    obj = preDo(obj);\n    if (mockJson && mockJson[obj.url]) {\n        // mock 模式\n        mock(obj);\n    } else {\n        getCache(obj, function (obj) {\n                checkSession(function () {\n                    request(obj);\n                }, obj)\n            }\n        )\n    }\n}\n\nfunction uploadFileWrapper(obj) {\n    obj = preDo(obj);\n    checkSession(function () {\n        uploadFile(obj);\n    }, obj)\n}\n\nfunction setSession(s) {\n    session        = s;\n    sessionIsFresh = true;\n}\n\nfunction mock(obj) {\n    var res = {\n        data: mockJson[obj.url]\n    };\n    if (successTrigger(res.data) && typeof obj.success === \"function\") {\n        // 接口返回成功码\n        obj.success(successData(res.data));\n    } else {\n        // 接口返回失败码\n        fail(obj, res);\n    }\n    if (typeof obj.complete === \"function\") {\n        obj.complete();\n    }\n}\n\nfunction getSession() {\n    return session;\n}\n\nfunction getConfig() {\n    return {\n        'urlPerfix': urlPerfix\n    }\n}\n\nmodule.exports = {\n    init: init,\n    request: requestWrapper,\n    uploadFile: uploadFileWrapper,\n    setSession: setSession,\n    login: login,\n    getSession: getSession,\n    getConfig: getConfig\n};"],"sourceRoot":""}
|