YesPlayMusic/packages/main/database.ts

133 lines
2.9 KiB
TypeScript
Raw Normal View History

2022-03-17 14:45:04 +08:00
import Realm from 'realm'
import type { FetchTracksResponse } from '../renderer/src/api/track'
2022-03-17 19:30:43 +08:00
import type { FetchAlbumResponse } from '../renderer/src/api/album'
2022-03-17 14:45:04 +08:00
enum ModelNames {
TRACK = 'Track',
2022-03-17 19:30:43 +08:00
ALBUM = 'Album',
ARTIST = 'Artist',
PLAYLIST = 'Playlist',
}
const universalProperties = {
id: 'int',
json: 'string',
updateAt: 'int',
2022-03-17 14:45:04 +08:00
}
const TrackSchema = {
name: ModelNames.TRACK,
2022-03-17 19:30:43 +08:00
properties: universalProperties,
primaryKey: 'id',
}
const AlbumSchema = {
name: ModelNames.ALBUM,
properties: universalProperties,
primaryKey: 'id',
}
const PlaylistSchema = {
name: ModelNames.PLAYLIST,
properties: universalProperties,
2022-03-17 14:45:04 +08:00
primaryKey: 'id',
}
const realm = new Realm({
2022-03-17 19:30:43 +08:00
path: './.tmp/db.realm',
schema: [TrackSchema, AlbumSchema, PlaylistSchema],
2022-03-17 14:45:04 +08:00
})
export const database = {
get: (model: ModelNames, key: number) => {
return realm.objectForPrimaryKey(model, key)
},
set: (model: ModelNames, key: number, value: any) => {
realm.create(
model,
{
id: key,
2022-03-17 19:30:43 +08:00
updateAt: Date.now(),
2022-03-17 14:45:04 +08:00
json: JSON.stringify(value),
},
'modified'
)
},
delete: (model: ModelNames, key: number) => {
realm.delete(realm.objectForPrimaryKey(model, key))
},
}
2022-03-17 19:30:43 +08:00
export async function setTracks(data: FetchTracksResponse) {
2022-03-17 14:45:04 +08:00
if (!data.songs) return
2022-03-17 19:30:43 +08:00
const tracks = data.songs
realm.write(() => {
tracks.forEach(track => {
database.set(ModelNames.TRACK, track.id, track)
2022-03-17 14:45:04 +08:00
})
2022-03-17 19:30:43 +08:00
})
2022-03-17 14:45:04 +08:00
}
export async function setCache(api: string, data: any) {
switch (api) {
2022-03-17 19:30:43 +08:00
case 'song_detail': {
2022-03-17 14:45:04 +08:00
setTracks(data)
2022-03-17 19:30:43 +08:00
return
}
case 'album': {
if (!data.album) return
realm.write(() => {
database.set(ModelNames.ALBUM, Number(data.album.id), data)
})
return
}
case 'playlist_detail': {
if (!data.playlist) return
realm.write(() => {
database.set(ModelNames.PLAYLIST, Number(data.playlist.id), data)
})
return
}
2022-03-17 14:45:04 +08:00
}
}
export function getCache(api: string, query: any) {
switch (api) {
case 'song_detail': {
2022-03-17 19:30:43 +08:00
const ids: string[] = query?.ids.split(',')
2022-03-17 14:45:04 +08:00
const idsQuery = ids.map(id => `id = ${id}`).join(' OR ')
const tracksRaw = realm
.objects(ModelNames.TRACK)
.filtered(`(${idsQuery})`)
if (tracksRaw.length !== ids.length) {
return
}
const tracks = tracksRaw.map(track => JSON.parse(track.json))
return {
code: 200,
songs: tracks,
privileges: {},
}
}
2022-03-17 19:30:43 +08:00
case 'album': {
if (!query?.id) return
const album = realm.objectForPrimaryKey(
ModelNames.ALBUM,
Number(query?.id)
)?.json
if (album) return JSON.parse(album)
return
}
case 'playlist_detail': {
if (!query?.id) return
const playlist = realm.objectForPrimaryKey(
ModelNames.PLAYLIST,
Number(query?.id)
)?.json
if (playlist) return JSON.parse(playlist)
return
}
2022-03-17 14:45:04 +08:00
}
}