refactor: escape filename

This commit is contained in:
Xmader 2020-11-24 17:35:44 -05:00
parent 6926600f45
commit 50ab62fff7
No known key found for this signature in database
GPG key ID: A20B97FB9EB730E4
3 changed files with 8 additions and 3 deletions

View file

@ -7,6 +7,7 @@ import fs from 'fs'
import { fetchMscz } from './mscz' import { fetchMscz } from './mscz'
import { loadMscore, INDV_DOWNLOADS, WebMscore } from './mscore' import { loadMscore, INDV_DOWNLOADS, WebMscore } from './mscore'
import { ScoreInfoHtml } from './scoreinfo' import { ScoreInfoHtml } from './scoreinfo'
import { escapeFilename } from './utils'
import i18n from './i18n' import i18n from './i18n'
const SCORE_URL_PREFIX = 'https://musescore.com/' const SCORE_URL_PREFIX = 'https://musescore.com/'
@ -99,7 +100,7 @@ void (async () => {
await Promise.all( await Promise.all(
filetypes.map(async (d) => { filetypes.map(async (d) => {
const data = await d.action(score) const data = await d.action(score)
const f = `${fileName} - ${encodeURIComponent(partName)}.${d.fileExt}` const f = `${fileName} - ${escapeFilename(partName)}.${d.fileExt}`
await fs.promises.writeFile(f, data) await fs.promises.writeFile(f, data)
spinner.info(`Saved ${chalk.underline(f)}`) spinner.info(`Saved ${chalk.underline(f)}`)
spinner.start() spinner.start()

View file

@ -1,5 +1,5 @@
import { getFetch } from './utils' import { getFetch, escapeFilename } from './utils'
export abstract class ScoreInfo { export abstract class ScoreInfo {
private readonly IPNS_KEY = 'QmSdXtvzC8v8iTTZuj5cVmiugnzbR1QATYRcGix4bBsioP'; private readonly IPNS_KEY = 'QmSdXtvzC8v8iTTZuj5cVmiugnzbR1QATYRcGix4bBsioP';
@ -15,7 +15,7 @@ export abstract class ScoreInfo {
} }
get fileName (): string { get fileName (): string {
return this.title.replace(/[\s<>:{}"/\\|?*~.\0\cA-\cZ]+/g, '_') return escapeFilename(this.title)
} }
get msczIpfsRef (): string { get msczIpfsRef (): string {

View file

@ -1,6 +1,10 @@
import isNodeJs from 'detect-node' import isNodeJs from 'detect-node'
export const escapeFilename = (s: string): string => {
return s.replace(/[\s<>:{}"/\\|?*~.\0\cA-\cZ]+/g, '_')
}
export const getIndexPath = (id: number): string => { export const getIndexPath = (id: number): string => {
const idStr = String(id) const idStr = String(id)
// 获取最后三位,倒序排列 // 获取最后三位,倒序排列