feat: 添加多项功能和修复

功能新增:
- OSS 存储使用情况显示(文件页面)
- OSS 当日流量统计(阿里云云监控API)
- 分享页面路由修复(/s/xxx 格式支持)

Bug修复:
- 修复分享页面资源路径(相对路径改绝对路径)
- 修复分享码获取逻辑(支持路径格式)
- 修复OSS配额undefined显示问题
- 修复登录流程OSS配置检查
- 修复文件数为null时的显示问题

依赖更新:
- 添加 @alicloud/cms20190101 云监控SDK
- 添加 @alicloud/openapi-client

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
This commit is contained in:
2026-01-22 21:04:22 +08:00
parent a86903fcdc
commit b135987fe8
3410 changed files with 494007 additions and 11 deletions

View File

@@ -0,0 +1,46 @@
/// <reference types="node" />
export default class Client {
/**
* Encode the URL
* @param url string
* @return encoded string
*/
static urlEncode(url: string): string;
/**
* Special encoding for url params.
* @param params string
* @return encoded string
*/
static percentEncode(raw: string): string;
/**
* Encode the partial path of url.
* @param path string
* @return encoded string
*/
static pathEncode(path: string): string;
/**
* Hex encode for byte array.
* @param raw byte array
* @return encoded string
*/
static hexEncode(raw: Buffer): string;
/**
* Hash the raw data with signatureAlgorithm.
* @param raw hashing data
* @param signatureAlgorithm the autograph method
* @return hashed bytes
*/
static hash(raw: Buffer, signatureAlgorithm: string): Buffer;
/**
* Base64 encoder for byte array.
* @param raw byte array
* @return encoded string
*/
static base64EncodeToString(raw: Buffer): string;
/**
* Base64 dncoder for string.
* @param src string
* @return dncoded byte array
*/
static base64Decode(src: string): Buffer;
}

View File

@@ -0,0 +1,121 @@
"use strict";
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
// This file is auto-generated, don't edit it
/**
* Encode Util for Darabonba.
*/
const crypto_1 = __importDefault(require("crypto"));
class Client {
/**
* Encode the URL
* @param url string
* @return encoded string
*/
static urlEncode(url) {
//URLEncoder.encode(url, URL_ENCODING)
return url != null ? encodeURIComponent(url) : '';
}
/**
* Special encoding for url params.
* @param params string
* @return encoded string
*/
static percentEncode(raw) {
return raw != null ? encodeURIComponent(raw).replace('+', '%20')
.replace('*', '%2A').replace('%7E', '~') : null;
}
/**
* Encode the partial path of url.
* @param path string
* @return encoded string
*/
static pathEncode(path) {
if (!path || path === '/') {
return path;
}
let paths = path.split('/');
let sb = [];
for (let s of paths) {
sb.push(Client.percentEncode(s));
}
return sb.join('/');
}
/**
* Hex encode for byte array.
* @param raw byte array
* @return encoded string
*/
static hexEncode(raw) {
if (raw === null) {
return null;
}
return raw.toString("hex");
}
/**
* Hash the raw data with signatureAlgorithm.
* @param raw hashing data
* @param signatureAlgorithm the autograph method
* @return hashed bytes
*/
static hash(raw, signatureAlgorithm) {
if (signatureAlgorithm == null) {
return null;
}
if (signatureAlgorithm.includes('HMAC-SHA256') || signatureAlgorithm.includes('RSA-SHA256')) {
const obj = crypto_1.default.createHash('sha256');
obj.update(raw);
return obj.digest();
}
else if (signatureAlgorithm.includes('HMAC-SM3')) {
const obj = crypto_1.default.createHash('sm3');
obj.update(raw);
return obj.digest();
}
}
/**
* Base64 encoder for byte array.
* @param raw byte array
* @return encoded string
*/
static base64EncodeToString(raw) {
return raw.toString('base64');
}
/**
* Base64 dncoder for string.
* @param src string
* @return dncoded byte array
*/
static base64Decode(src) {
/** Convert Base64 data to a string */
var toBinaryTable = [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 62, -1, -1, -1, 63,
52, 53, 54, 55, 56, 57, 58, 59, 60, 61, -1, -1, -1, 0, -1, -1, -1, 0, 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, -1, -1, -1, -1, -1, -1, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40,
41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, -1, -1, -1, -1, -1
];
var result = '';
var leftbits = 0;
var leftdata = 0;
for (var i = 0; i < src.length; i++) {
var c = toBinaryTable[src.charCodeAt(i) & 0x7f];
var padding = (src.charCodeAt(i) == '='.charCodeAt(0));
if (c == -1)
continue;
leftdata = (leftdata << 6) | c;
leftbits += 6;
if (leftbits >= 8) {
leftbits -= 8;
if (!padding)
result += String.fromCharCode((leftdata >> leftbits) & 0xff);
leftdata &= (1 << leftbits) - 1;
}
}
if (leftbits)
throw Error('Corrupted base64 string');
return Buffer.from(result);
}
}
exports.default = Client;
//# sourceMappingURL=client.js.map

View File

@@ -0,0 +1 @@
{"version":3,"file":"client.js","sourceRoot":"","sources":["../src/client.ts"],"names":[],"mappings":"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"}

View File

@@ -0,0 +1,38 @@
{
"name": "@alicloud/darabonba-encode-util",
"version": "0.0.2",
"description": "",
"main": "dist/client.js",
"scripts": {
"test": "mocha -r ts-node/register ./tests/*test.ts",
"test-cov": "nyc -e .ts -r=html -r=text -r=lcov npm run test",
"build": "tsc",
"prepublishOnly": "tsc"
},
"author": "",
"license": "ISC",
"devDependencies": {
"@types/chai": "^4.2.22",
"@types/mocha": "^9.0.0",
"@types/node": "^12.20.37",
"@types/should": "^13.0.0",
"@types/sinon": "^10.0.6",
"chai": "^4.3.4",
"cross-env": "^7.0.3",
"mocha": "^9.1.3",
"nyc": "^15.1.0",
"should": "^13.2.3",
"sinon": "^12.0.1",
"source-map-support": "^0.5.16",
"ts-node": "^8.10.2",
"tsconfig-paths": "^3.12.0",
"typescript": "^3.7.5"
},
"dependencies": {
"moment": "^2.29.1"
},
"files": [
"dist",
"src"
]
}

View File

@@ -0,0 +1,122 @@
// This file is auto-generated, don't edit it
/**
* Encode Util for Darabonba.
*/
import crypto from 'crypto';
export default class Client {
/**
* Encode the URL
* @param url string
* @return encoded string
*/
static urlEncode(url: string): string {
//URLEncoder.encode(url, URL_ENCODING)
return url != null ? encodeURIComponent(url) : '';
}
/**
* Special encoding for url params.
* @param params string
* @return encoded string
*/
static percentEncode(raw: string): string {
return raw != null ? encodeURIComponent(raw).replace('+', '%20')
.replace('*', '%2A').replace('%7E', '~') : null;
}
/**
* Encode the partial path of url.
* @param path string
* @return encoded string
*/
static pathEncode(path: string): string {
if (!path || path === '/') {
return path;
}
let paths = path.split('/');
let sb = [];
for (let s of paths) {
sb.push(Client.percentEncode(s));
}
return sb.join('/');
}
/**
* Hex encode for byte array.
* @param raw byte array
* @return encoded string
*/
static hexEncode(raw: Buffer): string {
if (raw === null) {
return null;
}
return raw.toString("hex");
}
/**
* Hash the raw data with signatureAlgorithm.
* @param raw hashing data
* @param signatureAlgorithm the autograph method
* @return hashed bytes
*/
static hash(raw: Buffer, signatureAlgorithm: string): Buffer {
if (signatureAlgorithm == null) {
return null;
}
if (signatureAlgorithm.includes('HMAC-SHA256') || signatureAlgorithm.includes('RSA-SHA256')) {
const obj = crypto.createHash('sha256');
obj.update(raw);
return obj.digest();
} else if (signatureAlgorithm.includes('HMAC-SM3')) {
const obj = crypto.createHash('sm3');
obj.update(raw);
return obj.digest();
}
}
/**
* Base64 encoder for byte array.
* @param raw byte array
* @return encoded string
*/
static base64EncodeToString(raw: Buffer): string {
return raw.toString('base64');
}
/**
* Base64 dncoder for string.
* @param src string
* @return dncoded byte array
*/
static base64Decode(src: string): Buffer {
/** Convert Base64 data to a string */
var toBinaryTable = [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 62, -1, -1, -1, 63,
52, 53, 54, 55, 56, 57, 58, 59, 60, 61, -1, -1, -1, 0, -1, -1, -1, 0, 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, -1, -1, -1, -1, -1, -1, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40,
41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, -1, -1, -1, -1, -1
];
var result = '';
var leftbits = 0;
var leftdata = 0;
for (var i = 0; i < src.length; i++) {
var c = toBinaryTable[src.charCodeAt(i) & 0x7f];
var padding = (src.charCodeAt(i) == '='.charCodeAt(0));
if (c == -1) continue;
leftdata = (leftdata << 6) | c;
leftbits += 6;
if (leftbits >= 8) {
leftbits -= 8;
if (!padding)
result += String.fromCharCode((leftdata >> leftbits) & 0xff);
leftdata &= (1 << leftbits) - 1;
}
}
if (leftbits)
throw Error('Corrupted base64 string');
return Buffer.from(result);
}
}