mirror of
https://github.com/d-fi/d-fi-core.git
synced 2025-07-27 07:34:42 +02:00
fix DataException
This commit is contained in:
parent
53ab1c1e75
commit
64832aee9d
@ -5,12 +5,12 @@ import type {albumTypePublicApi, trackType} from '../types';
|
|||||||
export const writeMetadataFlac = (
|
export const writeMetadataFlac = (
|
||||||
buffer: Buffer,
|
buffer: Buffer,
|
||||||
track: trackType,
|
track: trackType,
|
||||||
album: albumTypePublicApi,
|
album: albumTypePublicApi | null,
|
||||||
dimension: number,
|
dimension: number,
|
||||||
cover?: Buffer | null,
|
cover?: Buffer | null,
|
||||||
): Buffer => {
|
): Buffer => {
|
||||||
const flac = new Metaflac(buffer);
|
const flac = new Metaflac(buffer);
|
||||||
const RELEASE_YEAR = album.release_date.split('-')[0];
|
const RELEASE_YEAR = album ? album.release_date.split('-')[0] : null;
|
||||||
|
|
||||||
const artists = track.ART_NAME.split(
|
const artists = track.ART_NAME.split(
|
||||||
new RegExp(' featuring | feat. | Ft. | ft. | vs | vs. | x | - |, ', 'g'),
|
new RegExp(' featuring | feat. | Ft. | ft. | vs | vs. | x | - |, ', 'g'),
|
||||||
@ -18,24 +18,27 @@ export const writeMetadataFlac = (
|
|||||||
|
|
||||||
flac.setTag('TITLE=' + track.SNG_TITLE);
|
flac.setTag('TITLE=' + track.SNG_TITLE);
|
||||||
flac.setTag('ALBUM=' + track.ALB_TITLE);
|
flac.setTag('ALBUM=' + track.ALB_TITLE);
|
||||||
flac.setTag('GENRE=' + album.genres.data[0].name);
|
|
||||||
flac.setTag('RELEASETYPE=' + album.record_type);
|
|
||||||
flac.setTag('ARTIST=' + artists.join(', '));
|
flac.setTag('ARTIST=' + artists.join(', '));
|
||||||
flac.setTag('ALBUMARTIST=' + album.artist.name);
|
|
||||||
flac.setTag('TRACKNUMBER=' + track.TRACK_NUMBER);
|
flac.setTag('TRACKNUMBER=' + track.TRACK_NUMBER);
|
||||||
|
|
||||||
|
if (album) {
|
||||||
|
flac.setTag('GENRE=' + album.genres.data[0].name);
|
||||||
|
flac.setTag('RELEASETYPE=' + album.record_type);
|
||||||
|
flac.setTag('ALBUMARTIST=' + album.artist.name);
|
||||||
|
flac.setTag('BARCODE=' + album.upc);
|
||||||
|
flac.setTag('LABEL=' + album.label);
|
||||||
|
flac.setTag('DATE=' + album.release_date);
|
||||||
|
flac.setTag('YEAR=' + RELEASE_YEAR);
|
||||||
|
}
|
||||||
|
|
||||||
if (track.DISK_NUMBER) {
|
if (track.DISK_NUMBER) {
|
||||||
flac.setTag('DISCNUMBER=' + track.DISK_NUMBER);
|
flac.setTag('DISCNUMBER=' + track.DISK_NUMBER);
|
||||||
}
|
}
|
||||||
|
|
||||||
flac.setTag('ISRC=' + track.ISRC);
|
flac.setTag('ISRC=' + track.ISRC);
|
||||||
flac.setTag('BARCODE=' + album.upc);
|
|
||||||
flac.setTag('LABEL=' + album.label);
|
|
||||||
flac.setTag('LENGTH=' + track.DURATION);
|
flac.setTag('LENGTH=' + track.DURATION);
|
||||||
flac.setTag('MEDIA=Digital Media');
|
flac.setTag('MEDIA=Digital Media');
|
||||||
flac.setTag('TRACKNUMBER=' + track.TRACK_NUMBER);
|
flac.setTag('TRACKNUMBER=' + track.TRACK_NUMBER);
|
||||||
flac.setTag('YEAR=' + RELEASE_YEAR);
|
|
||||||
flac.setTag('DATE=' + album.release_date);
|
|
||||||
|
|
||||||
if (track.LYRICS) {
|
if (track.LYRICS) {
|
||||||
flac.setTag('LYRICS=' + track.LYRICS.LYRICS_TEXT);
|
flac.setTag('LYRICS=' + track.LYRICS.LYRICS_TEXT);
|
||||||
@ -46,7 +49,7 @@ export const writeMetadataFlac = (
|
|||||||
|
|
||||||
if (track.SNG_CONTRIBUTORS && !Array.isArray(track.SNG_CONTRIBUTORS)) {
|
if (track.SNG_CONTRIBUTORS && !Array.isArray(track.SNG_CONTRIBUTORS)) {
|
||||||
if (track.SNG_CONTRIBUTORS.main_artist) {
|
if (track.SNG_CONTRIBUTORS.main_artist) {
|
||||||
flac.setTag(`COPYRIGHT=${RELEASE_YEAR} ${track.SNG_CONTRIBUTORS.main_artist[0]}`);
|
flac.setTag(`COPYRIGHT=${RELEASE_YEAR ? RELEASE_YEAR + ' ' : ''}${track.SNG_CONTRIBUTORS.main_artist[0]}`);
|
||||||
}
|
}
|
||||||
if (track.SNG_CONTRIBUTORS.publisher) {
|
if (track.SNG_CONTRIBUTORS.publisher) {
|
||||||
flac.setTag('ORGANIZATION=' + track.SNG_CONTRIBUTORS.publisher.join(', '));
|
flac.setTag('ORGANIZATION=' + track.SNG_CONTRIBUTORS.publisher.join(', '));
|
||||||
|
@ -5,11 +5,11 @@ import type {albumTypePublicApi, trackType} from '../types';
|
|||||||
export const writeMetadataMp3 = (
|
export const writeMetadataMp3 = (
|
||||||
buffer: Buffer,
|
buffer: Buffer,
|
||||||
track: trackType,
|
track: trackType,
|
||||||
album: albumTypePublicApi,
|
album: albumTypePublicApi | null,
|
||||||
cover?: Buffer | null,
|
cover?: Buffer | null,
|
||||||
): Buffer => {
|
): Buffer => {
|
||||||
const writer = new id3Writer(buffer);
|
const writer = new id3Writer(buffer);
|
||||||
const RELEASE_YEAR = album.release_date.split('-')[0];
|
const RELEASE_YEAR = album ? album.release_date.split('-')[0] : null;
|
||||||
|
|
||||||
const artists = track.ART_NAME.split(
|
const artists = track.ART_NAME.split(
|
||||||
new RegExp(' featuring | feat. | Ft. | ft. | vs | vs. | x | - |, ', 'g'),
|
new RegExp(' featuring | feat. | Ft. | ft. | vs | vs. | x | - |, ', 'g'),
|
||||||
@ -18,36 +18,42 @@ export const writeMetadataMp3 = (
|
|||||||
writer
|
writer
|
||||||
.setFrame('TIT2', track.SNG_TITLE)
|
.setFrame('TIT2', track.SNG_TITLE)
|
||||||
.setFrame('TALB', track.ALB_TITLE)
|
.setFrame('TALB', track.ALB_TITLE)
|
||||||
.setFrame(
|
|
||||||
'TCON',
|
|
||||||
album.genres.data.map((g) => g.name),
|
|
||||||
)
|
|
||||||
.setFrame('TPE1', [artists])
|
.setFrame('TPE1', [artists])
|
||||||
.setFrame('TPE2', album.artist.name)
|
.setFrame('TLEN', Number(track.DURATION) * 1000);
|
||||||
.setFrame('TLEN', Number(track.DURATION) * 1000)
|
|
||||||
.setFrame('TYER', RELEASE_YEAR)
|
if (album) {
|
||||||
.setFrame('TDAT', album.release_date)
|
writer
|
||||||
|
.setFrame(
|
||||||
|
'TCON',
|
||||||
|
album.genres.data.map((g) => g.name),
|
||||||
|
)
|
||||||
|
.setFrame('TPE2', album.artist.name)
|
||||||
|
.setFrame('TYER', RELEASE_YEAR)
|
||||||
|
.setFrame('TDAT', album.release_date)
|
||||||
|
.setFrame('TXXX', {
|
||||||
|
description: 'RELEASETYPE',
|
||||||
|
value: album.record_type,
|
||||||
|
})
|
||||||
|
.setFrame('TXXX', {
|
||||||
|
description: 'BARCODE',
|
||||||
|
value: album.upc,
|
||||||
|
})
|
||||||
|
.setFrame('TXXX', {
|
||||||
|
description: 'LABEL',
|
||||||
|
value: album.label,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
writer
|
||||||
.setFrame('TMED', 'Digital Media')
|
.setFrame('TMED', 'Digital Media')
|
||||||
.setFrame('TXXX', {
|
.setFrame('TXXX', {
|
||||||
description: 'Artists',
|
description: 'Artists',
|
||||||
value: artists.join(', '),
|
value: artists.join(', '),
|
||||||
})
|
})
|
||||||
.setFrame('TXXX', {
|
|
||||||
description: 'RELEASETYPE',
|
|
||||||
value: album.record_type,
|
|
||||||
})
|
|
||||||
.setFrame('TXXX', {
|
.setFrame('TXXX', {
|
||||||
description: 'ISRC',
|
description: 'ISRC',
|
||||||
value: track.ISRC,
|
value: track.ISRC,
|
||||||
})
|
})
|
||||||
.setFrame('TXXX', {
|
|
||||||
description: 'BARCODE',
|
|
||||||
value: album.upc,
|
|
||||||
})
|
|
||||||
.setFrame('TXXX', {
|
|
||||||
description: 'LABEL',
|
|
||||||
value: album.label,
|
|
||||||
})
|
|
||||||
.setFrame('TXXX', {
|
.setFrame('TXXX', {
|
||||||
description: 'COMPILATION',
|
description: 'COMPILATION',
|
||||||
value: track.ART_PICTURE === 'Various Artists' ? '1' : '0',
|
value: track.ART_PICTURE === 'Various Artists' ? '1' : '0',
|
||||||
@ -62,12 +68,14 @@ export const writeMetadataMp3 = (
|
|||||||
});
|
});
|
||||||
|
|
||||||
if (track.DISK_NUMBER) {
|
if (track.DISK_NUMBER) {
|
||||||
writer.setFrame('TPOS', track.DISK_NUMBER).setFrame('TRCK', track.TRACK_NUMBER + '/' + album.nb_tracks);
|
writer
|
||||||
|
.setFrame('TPOS', track.DISK_NUMBER)
|
||||||
|
.setFrame('TRCK', `${track.TRACK_NUMBER}${album ? '/' + album.nb_tracks : ''}`);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (track.SNG_CONTRIBUTORS && !Array.isArray(track.SNG_CONTRIBUTORS)) {
|
if (track.SNG_CONTRIBUTORS && !Array.isArray(track.SNG_CONTRIBUTORS)) {
|
||||||
if (track.SNG_CONTRIBUTORS.main_artist) {
|
if (track.SNG_CONTRIBUTORS.main_artist) {
|
||||||
writer.setFrame('TCOP', `${RELEASE_YEAR} ${track.SNG_CONTRIBUTORS.main_artist[0]}`);
|
writer.setFrame('TCOP', `${RELEASE_YEAR ? RELEASE_YEAR + ' ' : ''}${track.SNG_CONTRIBUTORS.main_artist[0]}`);
|
||||||
}
|
}
|
||||||
if (track.SNG_CONTRIBUTORS.publisher) {
|
if (track.SNG_CONTRIBUTORS.publisher) {
|
||||||
writer.setFrame('TPUB', track.SNG_CONTRIBUTORS.publisher.join(', '));
|
writer.setFrame('TPUB', track.SNG_CONTRIBUTORS.publisher.join(', '));
|
||||||
|
@ -2,15 +2,14 @@ import {downloadAlbumCover} from './abumCover';
|
|||||||
import {getTrackLyrics} from './getTrackLyrics';
|
import {getTrackLyrics} from './getTrackLyrics';
|
||||||
import {writeMetadataMp3} from './id3';
|
import {writeMetadataMp3} from './id3';
|
||||||
import {writeMetadataFlac} from './flacmetata';
|
import {writeMetadataFlac} from './flacmetata';
|
||||||
import {getAlbumInfoPublicApi, getTrackInfoPublicApi} from '../api';
|
import {getAlbumInfoPublicApi} from '../api';
|
||||||
import type {trackType} from '../types';
|
import type {trackType} from '../types';
|
||||||
|
|
||||||
const albumInfo = async (track: trackType) => {
|
const albumInfo = async (track: trackType) => {
|
||||||
try {
|
try {
|
||||||
return getAlbumInfoPublicApi(track.ALB_ID);
|
return getAlbumInfoPublicApi(track.ALB_ID);
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
const {album} = await getTrackInfoPublicApi(track.SNG_ID);
|
return null;
|
||||||
return getAlbumInfoPublicApi(album.id.toString());
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -34,8 +33,10 @@ export const addTrackTags = async (trackBuffer: Buffer, track: trackType, albumC
|
|||||||
if (track.ART_NAME.toLowerCase() === 'various') {
|
if (track.ART_NAME.toLowerCase() === 'various') {
|
||||||
track.ART_NAME = 'Various Artists';
|
track.ART_NAME = 'Various Artists';
|
||||||
}
|
}
|
||||||
album.record_type =
|
if (album && album.record_type) {
|
||||||
album.record_type === 'ep' ? 'EP' : album.record_type.charAt(0).toUpperCase() + album.record_type.slice(1);
|
album.record_type =
|
||||||
|
album.record_type === 'ep' ? 'EP' : album.record_type.charAt(0).toUpperCase() + album.record_type.slice(1);
|
||||||
|
}
|
||||||
|
|
||||||
const isFlac = trackBuffer.slice(0, 4).toString('ascii') === 'fLaC';
|
const isFlac = trackBuffer.slice(0, 4).toString('ascii') === 'fLaC';
|
||||||
return isFlac
|
return isFlac
|
||||||
|
Loading…
x
Reference in New Issue
Block a user