cube.js 自定义checkAuth 响应状态码

如果阅读源码了,会发现默认是基于UserError 进行处理的,但是默认只有403,解决方法

参考源码

通过以下源码可以看到内部处理

 protected checkAuth: RequestHandler = async (req, res, next) => {
    const token = this.extractAuthorizationHeaderWithSchema(req);
 
    try {
      await this.checkAuthFn(req, token);
      if (next) {
        next();
      }
    } catch (e) {
      if (e instanceof UserError) {
         // 此处需要修改为e.status, 对于需要自定义状态码的可以自己搞一个error 实现
        res.status(403).json({ error: e.message });
      } else {
        this.log({
          type: 'Auth Error',
          token,
          error: e.stack || e.toString()
        }, <any>req);
        res.status(500).json({ error: e.toString() });
      }
    }
  };

自定义Error 解决

const CubejsServer = require('@cubejs-backend/server');
const {UserError} = require("@cubejs-backend/api-gateway")
 
 
class MyUserError extends UserError {
    constructor(message){
       super(message)
        // 改写自定义异常状态码
       this.status=401
    }
}
const server = new CubejsServer({
    checkAuth: (ob) => {
        throw new MyUserError('Could not authenticate user from LDAP');
    }
});
 
server.listen().then(({ version, port }) => {
  console.log(`🚀 Cube.js server (${version}) is listening on ${port}`);
});

说明

官方目前也已经支持了次功能了,参考官方pr https://github.com/cube-js/cube.js/pull/2568

posted on   荣锋亮  阅读(150)  评论(0编辑  收藏  举报

编辑推荐:
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· .NET10 - 预览版1新功能体验(一)
历史上的今天:
2020-04-16 easy-rules spring boot 一个简单的starter
2019-04-16 websocket 2 rest api
2019-04-16 编写一个简单的基于jmespath 的prometheus exporter
2014-04-16 search bar 创建的一些文章

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示