@lytjs/plugin-auth 4.0.5 → 4.2.0

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.
package/dist/index.cjs CHANGED
@@ -1 +1 @@
1
- "use strict";var T=Object.defineProperty;var j=Object.getOwnPropertyDescriptor;var C=Object.getOwnPropertyNames;var H=Object.prototype.hasOwnProperty;var D=(s,t)=>{for(var o in t)T(s,o,{get:t[o],enumerable:!0})},F=(s,t,o,l)=>{if(t&&typeof t=="object"||typeof t=="function")for(let a of C(t))!H.call(s,a)&&a!==o&&T(s,a,{get:()=>t[a],enumerable:!(l=j(t,a))||l.enumerable});return s};var M=s=>F(T({},"__esModule",{value:!0}),s);var W={};D(W,{createAuth:()=>V});module.exports=M(W);async function O(s,t={}){let o=await fetch(s,{headers:{"Content-Type":"application/json",...t.headers},...t});if(!o.ok){let a=await o.text().catch(()=>"\u8BF7\u6C42\u5931\u8D25");throw new Error(`HTTP ${o.status}: ${a}`)}let l=await o.text();if(!l)return null;try{return JSON.parse(l)}catch(a){return l}}async function Q(s,t){let o={};return t&&(o.Authorization=`Bearer ${t}`),O(s,{method:"GET",headers:o})}async function h(s,t,o){let l={};return o&&(l.Authorization=`Bearer ${o}`),O(s,{method:"POST",headers:l,body:JSON.stringify(t)})}function V(s){let{loginUrl:t,logoutUrl:o,userUrl:l,registerUrl:a,refreshTokenUrl:p,tokenKey:y="lyt_token",autoRedirect:q=!1,loginRoute:v="/login",homeRoute:I="/",onLoginSuccess:P,onLoginError:w,onLogout:R,onUnauthorized:A,onTokenRefreshed:U,onTokenRefreshError:b}=s,i=null,c=null,f=!1;try{let r=localStorage.getItem(y);r&&(c=r)}catch(r){}function E(){return!!c}function _(){return c}function d(r){c=r;try{localStorage.setItem(y,r)}catch(e){}}function m(){c=null;try{localStorage.removeItem(y)}catch(r){}}async function L(){if(!l)return i;f=!0;try{return i=await Q(l,c),i}catch(r){throw i=null,r}finally{f=!1}}async function $(r){var e,u;f=!0;try{let n=await h(t,r,null),g=(n==null?void 0:n.token)||(n==null?void 0:n.access_token)||((e=n==null?void 0:n.data)==null?void 0:e.token)||null;return g&&d(g),l?await L():(n!=null&&n.user||(u=n==null?void 0:n.data)!=null&&u.user)&&(i=n.user||n.data.user),P&&P(i),{user:i,token:g}}catch(n){throw w&&n instanceof Error&&w(n),n}finally{f=!1}}async function z(){f=!0;try{if(o&&c)try{await h(o,{},c)}catch(e){}let r=i;m(),i=null,R&&R()}finally{f=!1}}async function x(r){if(!a)throw new Error("\u672A\u914D\u7F6E registerUrl\uFF0C\u65E0\u6CD5\u6CE8\u518C");f=!0;try{return await h(a,r,null)}finally{f=!1}}async function G(){var r;if(!p)throw new Error("\u672A\u914D\u7F6E refreshTokenUrl\uFF0C\u65E0\u6CD5\u5237\u65B0 Token");if(!c)return null;f=!0;try{let e=await h(p,{},c),u=(e==null?void 0:e.token)||(e==null?void 0:e.access_token)||((r=e==null?void 0:e.data)==null?void 0:r.token)||null;return u&&(d(u),U&&U(u)),u}catch(e){throw b&&e instanceof Error&&b(e),m(),i=null,e}finally{f=!1}}function B(r){if(!i)return!1;let e=i.roles||i.role||[];return Array.isArray(e)?e.includes(r):typeof e=="string"?e.split(",").map(u=>u.trim()).includes(r):!1}function J(r){if(!i)return!1;let e=i.permissions||i.perms||[];return Array.isArray(e)?e.includes(r):typeof e=="string"?e.split(",").map(u=>u.trim()).includes(r):!1}function K(r){!r||typeof r.beforeEach!="function"||r.beforeEach((e,u,n)=>{var S;let g=((S=e.meta)==null?void 0:S.requiresAuth)!==!1,N=e.path===v;if(E()){if(N){n(I);return}n();return}if(g&&q){n({path:v,query:{redirect:e.fullPath}});return}g&&A&&A(),n()})}let k={install(r,e){r.config=r.config||{},r.config.globalProperties=r.config.globalProperties||{},r.config.globalProperties.$auth=k,typeof r.provide=="function"&&r.provide("auth",k)},get user(){return i},get isAuthenticated(){return E()},get token(){return c},get loading(){return f},login:$,logout:z,register:x,fetchUser:L,getToken:_,setToken:d,removeToken:m,hasRole:B,hasPermission:J,refreshToken:G,setupRouterGuard:K};return k}
1
+ var T=Object.defineProperty;var j=Object.getOwnPropertyDescriptor;var C=Object.getOwnPropertyNames;var H=Object.prototype.hasOwnProperty;var D=(s,t)=>{for(var o in t)T(s,o,{get:t[o],enumerable:!0})},F=(s,t,o,l)=>{if(t&&typeof t=="object"||typeof t=="function")for(let a of C(t))!H.call(s,a)&&a!==o&&T(s,a,{get:()=>t[a],enumerable:!(l=j(t,a))||l.enumerable});return s};var M=s=>F(T({},"__esModule",{value:!0}),s);var W={};D(W,{createAuth:()=>V});module.exports=M(W);async function O(s,t={}){let o=await fetch(s,{headers:{"Content-Type":"application/json",...t.headers},...t});if(!o.ok){let a=await o.text().catch(()=>"\u8BF7\u6C42\u5931\u8D25");throw new Error(`HTTP ${o.status}: ${a}`)}let l=await o.text();if(!l)return null;try{return JSON.parse(l)}catch(a){return l}}async function Q(s,t){let o={};return t&&(o.Authorization=`Bearer ${t}`),O(s,{method:"GET",headers:o})}async function h(s,t,o){let l={};return o&&(l.Authorization=`Bearer ${o}`),O(s,{method:"POST",headers:l,body:JSON.stringify(t)})}function V(s){let{loginUrl:t,logoutUrl:o,userUrl:l,registerUrl:a,refreshTokenUrl:p,tokenKey:y="lyt_token",autoRedirect:q=!1,loginRoute:v="/login",homeRoute:I="/",onLoginSuccess:P,onLoginError:w,onLogout:R,onUnauthorized:A,onTokenRefreshed:U,onTokenRefreshError:b}=s,i=null,c=null,f=!1;try{let r=localStorage.getItem(y);r&&(c=r)}catch(r){}function E(){return!!c}function _(){return c}function d(r){c=r;try{localStorage.setItem(y,r)}catch(e){}}function m(){c=null;try{localStorage.removeItem(y)}catch(r){}}async function L(){if(!l)return i;f=!0;try{return i=await Q(l,c),i}catch(r){throw i=null,r}finally{f=!1}}async function $(r){var e,u;f=!0;try{let n=await h(t,r,null),g=(n==null?void 0:n.token)||(n==null?void 0:n.access_token)||((e=n==null?void 0:n.data)==null?void 0:e.token)||null;return g&&d(g),l?await L():(n!=null&&n.user||(u=n==null?void 0:n.data)!=null&&u.user)&&(i=n.user||n.data.user),P&&P(i),{user:i,token:g}}catch(n){throw w&&n instanceof Error&&w(n),n}finally{f=!1}}async function z(){f=!0;try{if(o&&c)try{await h(o,{},c)}catch(e){}let r=i;m(),i=null,R&&R()}finally{f=!1}}async function x(r){if(!a)throw new Error("\u672A\u914D\u7F6E registerUrl\uFF0C\u65E0\u6CD5\u6CE8\u518C");f=!0;try{return await h(a,r,null)}finally{f=!1}}async function G(){var r;if(!p)throw new Error("\u672A\u914D\u7F6E refreshTokenUrl\uFF0C\u65E0\u6CD5\u5237\u65B0 Token");if(!c)return null;f=!0;try{let e=await h(p,{},c),u=(e==null?void 0:e.token)||(e==null?void 0:e.access_token)||((r=e==null?void 0:e.data)==null?void 0:r.token)||null;return u&&(d(u),U&&U(u)),u}catch(e){throw b&&e instanceof Error&&b(e),m(),i=null,e}finally{f=!1}}function B(r){if(!i)return!1;let e=i.roles||i.role||[];return Array.isArray(e)?e.includes(r):typeof e=="string"?e.split(",").map(u=>u.trim()).includes(r):!1}function J(r){if(!i)return!1;let e=i.permissions||i.perms||[];return Array.isArray(e)?e.includes(r):typeof e=="string"?e.split(",").map(u=>u.trim()).includes(r):!1}function K(r){!r||typeof r.beforeEach!="function"||r.beforeEach((e,u,n)=>{var S;let g=((S=e.meta)==null?void 0:S.requiresAuth)!==!1,N=e.path===v;if(E()){if(N){n(I);return}n();return}if(g&&q){n({path:v,query:{redirect:e.fullPath}});return}g&&A&&A(),n()})}let k={install(r,e){r.config=r.config||{},r.config.globalProperties=r.config.globalProperties||{},r.config.globalProperties.$auth=k,typeof r.provide=="function"&&r.provide("auth",k)},get user(){return i},get isAuthenticated(){return E()},get token(){return c},get loading(){return f},login:$,logout:z,register:x,fetchUser:L,getToken:_,setToken:d,removeToken:m,hasRole:B,hasPermission:J,refreshToken:G,setupRouterGuard:K};return k}
@@ -0,0 +1,77 @@
1
+ /** 认证配置选项 */
2
+ interface AuthOptions {
3
+ /** 登录接口地址 */
4
+ loginUrl: string;
5
+ /** 登出接口地址 */
6
+ logoutUrl?: string;
7
+ /** 获取当前用户信息接口地址 */
8
+ userUrl?: string;
9
+ /** 注册接口地址 */
10
+ registerUrl?: string;
11
+ /** Token 刷新接口地址 */
12
+ refreshTokenUrl?: string;
13
+ /** localStorage 中存储 token 的 key,默认 'lyt_token' */
14
+ tokenKey?: string;
15
+ /** 未登录时是否自动跳转到登录页 */
16
+ autoRedirect?: boolean;
17
+ /** 登录页路由路径 */
18
+ loginRoute?: string;
19
+ /** 登录后跳转的路由路径 */
20
+ homeRoute?: string;
21
+ /** 登录成功回调 */
22
+ onLoginSuccess?: (user: any) => void;
23
+ /** 登录失败回调 */
24
+ onLoginError?: (error: Error) => void;
25
+ /** 登出回调 */
26
+ onLogout?: () => void;
27
+ /** 未授权回调(401 等) */
28
+ onUnauthorized?: () => void;
29
+ /** Token 刷新成功回调 */
30
+ onTokenRefreshed?: (newToken: string) => void;
31
+ /** Token 刷新失败回调 */
32
+ onTokenRefreshError?: (error: Error) => void;
33
+ }
34
+ /** 认证插件实例 */
35
+ interface Auth {
36
+ /** 安装到 Lyt 应用 */
37
+ install: (app: any, options?: any) => void;
38
+ /** 当前用户信息 */
39
+ user: any | null;
40
+ /** 是否已认证 */
41
+ isAuthenticated: boolean;
42
+ /** 当前 token */
43
+ token: string | null;
44
+ /** 是否正在加载中 */
45
+ loading: boolean;
46
+ /** 登录 */
47
+ login(credentials: Record<string, any>): Promise<any>;
48
+ /** 登出 */
49
+ logout(): Promise<void>;
50
+ /** 注册 */
51
+ register(data: Record<string, any>): Promise<any>;
52
+ /** 获取当前用户信息 */
53
+ fetchUser(): Promise<any>;
54
+ /** 获取 token */
55
+ getToken(): string | null;
56
+ /** 设置 token */
57
+ setToken(token: string): void;
58
+ /** 移除 token */
59
+ removeToken(): void;
60
+ /** 检查用户是否拥有指定角色 */
61
+ hasRole(role: string): boolean;
62
+ /** 检查用户是否拥有指定权限 */
63
+ hasPermission(perm: string): boolean;
64
+ /** 刷新 Token */
65
+ refreshToken(): Promise<string | null>;
66
+ /** 设置路由守卫,自动检查登录状态 */
67
+ setupRouterGuard(router: any): void;
68
+ }
69
+ /**
70
+ * 创建认证授权插件实例
71
+ * @param options 认证配置
72
+ * @returns Auth 插件实例
73
+ */
74
+ declare function createAuth(options: AuthOptions): Auth;
75
+ export { createAuth };
76
+ export type { Auth, AuthOptions };
77
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAsBA,aAAa;AACb,UAAU,WAAW;IACnB,aAAa;IACb,QAAQ,EAAE,MAAM,CAAA;IAChB,aAAa;IACb,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,mBAAmB;IACnB,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,aAAa;IACb,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,mBAAmB;IACnB,eAAe,CAAC,EAAE,MAAM,CAAA;IACxB,kDAAkD;IAClD,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,qBAAqB;IACrB,YAAY,CAAC,EAAE,OAAO,CAAA;IACtB,cAAc;IACd,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,iBAAiB;IACjB,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,aAAa;IACb,cAAc,CAAC,EAAE,CAAC,IAAI,EAAE,GAAG,KAAK,IAAI,CAAA;IACpC,aAAa;IACb,YAAY,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,KAAK,IAAI,CAAA;IACrC,WAAW;IACX,QAAQ,CAAC,EAAE,MAAM,IAAI,CAAA;IACrB,mBAAmB;IACnB,cAAc,CAAC,EAAE,MAAM,IAAI,CAAA;IAC3B,mBAAmB;IACnB,gBAAgB,CAAC,EAAE,CAAC,QAAQ,EAAE,MAAM,KAAK,IAAI,CAAA;IAC7C,mBAAmB;IACnB,mBAAmB,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,KAAK,IAAI,CAAA;CAC7C;AAED,aAAa;AACb,UAAU,IAAI;IACZ,iBAAiB;IACjB,OAAO,EAAE,CAAC,GAAG,EAAE,GAAG,EAAE,OAAO,CAAC,EAAE,GAAG,KAAK,IAAI,CAAA;IAC1C,aAAa;IACb,IAAI,EAAE,GAAG,GAAG,IAAI,CAAA;IAChB,YAAY;IACZ,eAAe,EAAE,OAAO,CAAA;IACxB,eAAe;IACf,KAAK,EAAE,MAAM,GAAG,IAAI,CAAA;IACpB,cAAc;IACd,OAAO,EAAE,OAAO,CAAA;IAChB,SAAS;IACT,KAAK,CAAC,WAAW,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,OAAO,CAAC,GAAG,CAAC,CAAA;IACrD,SAAS;IACT,MAAM,IAAI,OAAO,CAAC,IAAI,CAAC,CAAA;IACvB,SAAS;IACT,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,OAAO,CAAC,GAAG,CAAC,CAAA;IACjD,eAAe;IACf,SAAS,IAAI,OAAO,CAAC,GAAG,CAAC,CAAA;IACzB,eAAe;IACf,QAAQ,IAAI,MAAM,GAAG,IAAI,CAAA;IACzB,eAAe;IACf,QAAQ,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI,CAAA;IAC7B,eAAe;IACf,WAAW,IAAI,IAAI,CAAA;IACnB,mBAAmB;IACnB,OAAO,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAA;IAC9B,mBAAmB;IACnB,aAAa,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAA;IACpC,eAAe;IACf,YAAY,IAAI,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CAAA;IACtC,sBAAsB;IACtB,gBAAgB,CAAC,MAAM,EAAE,GAAG,GAAG,IAAI,CAAA;CACpC;AA+DD;;;;GAIG;AACH,iBAAS,UAAU,CAAC,OAAO,EAAE,WAAW,GAAG,IAAI,CAsU9C;AAED,OAAO,EAAE,UAAU,EAAE,CAAA;AACrB,YAAY,EAAE,IAAI,EAAE,WAAW,EAAE,CAAA"}
package/package.json CHANGED
@@ -1,14 +1,16 @@
1
1
  {
2
2
  "name": "@lytjs/plugin-auth",
3
- "version": "4.0.5",
3
+ "version": "4.2.0",
4
4
  "description": "Lyt.js 认证授权插件 - 提供登录、权限校验、路由守卫等认证功能",
5
- "main": "./src/index.ts",
6
- "module": "./src/index.ts",
5
+ "main": "./dist/index.cjs",
6
+ "module": "./dist/index.mjs",
7
+ "types": "./dist/types/index.d.ts",
7
8
  "exports": {
8
9
  ".": {
9
- "import": "./src/index.ts",
10
- "require": "./src/index.ts",
11
- "default": "./src/index.ts"
10
+ "types": "./dist/types/index.d.ts",
11
+ "import": "./dist/index.mjs",
12
+ "require": "./dist/index.cjs",
13
+ "default": "./dist/index.mjs"
12
14
  }
13
15
  },
14
16
  "sideEffects": false,