feat: update instructions for kwmv2 key import

This commit is contained in:
鲁树人 2023-06-17 14:55:38 +01:00
parent 1a8e7db9be
commit 57979ccbb3
7 changed files with 58 additions and 17 deletions

View File

@ -17,10 +17,22 @@ import { ExternalLinkIcon } from '@chakra-ui/icons';
import { Light as SyntaxHighlighter } from 'react-syntax-highlighter'; import { Light as SyntaxHighlighter } from 'react-syntax-highlighter';
import hljsStyleGitHub from 'react-syntax-highlighter/dist/esm/styles/hljs/github'; import hljsStyleGitHub from 'react-syntax-highlighter/dist/esm/styles/hljs/github';
import PowerShellAdbDumpCommand from './adb_dump.ps1?raw'; import PowerShellAdbDumpCommandTemplate from './adb_dump.ps1?raw';
import ShellAdbDumpCommand from './adb_dump.sh?raw'; import ShellAdbDumpCommandTemplate from './adb_dump.sh?raw';
const applyTemplate = (tpl: string, values: Record<string, unknown>) => {
return tpl.replace(/\{\{\s*(\w+)\s*\}\}/g, (_, key) => (Object.hasOwn(values, key) ? String(values[key]) : '<nil>'));
};
export interface AndroidADBPullInstructionProps {
dir: string;
file: string;
}
export function AndroidADBPullInstruction({ dir, file }: AndroidADBPullInstructionProps) {
const psAdbDumpCommand = applyTemplate(PowerShellAdbDumpCommandTemplate, { dir, file });
const shAdbDumpCommand = applyTemplate(ShellAdbDumpCommandTemplate, { dir, file });
export function InstructionsAndroid() {
return ( return (
<> <>
<Text> <Text>
@ -50,12 +62,12 @@ export function InstructionsAndroid() {
</ListItem> </ListItem>
<ListItem> <ListItem>
<Text> <Text>
访 <Code>/data/data/com.tencent.qqmusic/databases/</Code> 访 <Code>{dir}/</Code>
</Text> </Text>
</ListItem> </ListItem>
<ListItem> <ListItem>
<Text> <Text>
<Code>player_process_db</Code> 访 <Code>{file}</Code> 访
<br /> <br />
</Text> </Text>
@ -99,12 +111,12 @@ export function InstructionsAndroid() {
<ListItem> <ListItem>
<Text></Text> <Text></Text>
<SyntaxHighlighter language="ps1" style={hljsStyleGitHub}> <SyntaxHighlighter language="ps1" style={hljsStyleGitHub}>
{PowerShellAdbDumpCommand} {psAdbDumpCommand}
</SyntaxHighlighter> </SyntaxHighlighter>
</ListItem> </ListItem>
<ListItem> <ListItem>
<Text> <Text>
<Code>player_process_db</Code> <Code>{file}</Code>
</Text> </Text>
</ListItem> </ListItem>
</OrderedList> </OrderedList>
@ -128,12 +140,12 @@ export function InstructionsAndroid() {
<ListItem> <ListItem>
<Text></Text> <Text></Text>
<SyntaxHighlighter language="bash" style={hljsStyleGitHub}> <SyntaxHighlighter language="bash" style={hljsStyleGitHub}>
{ShellAdbDumpCommand} {shAdbDumpCommand}
</SyntaxHighlighter> </SyntaxHighlighter>
</ListItem> </ListItem>
<ListItem> <ListItem>
<Text> <Text>
<Code>player_process_db</Code> <Code>{file}</Code>
</Text> </Text>
</ListItem> </ListItem>
</OrderedList> </OrderedList>

View File

@ -1,8 +1,8 @@
try { try {
$gz_b64 = adb shell su -c "cat '/data/data/com.tencent.qqmusic/databases/player_process_db' | gzip | base64" | Out-String $gz_b64 = adb shell su -c "cat '{{ dir }}/{{ file }}' | gzip | base64" | Out-String
$bStream = New-Object System.IO.MemoryStream(,[System.Convert]::FromBase64String($gz_b64)) $bStream = New-Object System.IO.MemoryStream(,[System.Convert]::FromBase64String($gz_b64))
$decoded = New-Object System.IO.Compression.GzipStream($bStream, [System.IO.Compression.CompressionMode]::Decompress) $decoded = New-Object System.IO.Compression.GzipStream($bStream, [System.IO.Compression.CompressionMode]::Decompress)
$outFile = New-Object System.IO.FileStream("player_process_db", [System.IO.FileMode]::Create, [System.IO.FileAccess]::Write) $outFile = New-Object System.IO.FileStream("{{ file }}", [System.IO.FileMode]::Create, [System.IO.FileAccess]::Write)
$decoded.CopyTo($outFile) $decoded.CopyTo($outFile)
} finally { } finally {
if ($outFile -ne $null) { $outFile.Dispose() } if ($outFile -ne $null) { $outFile.Dispose() }

View File

@ -0,0 +1,2 @@
sh adb shell su -c "cat '{{ dir }}/{{ file }}' | gzip | base64" \
| base64 -d | gzip -d '{{ file }}'

View File

@ -0,0 +1,9 @@
import { Text } from '@chakra-ui/react';
export function InstructionsPC() {
return (
<>
<Text>使 Windows </Text>
</>
);
}

View File

@ -14,6 +14,10 @@ import {
MenuDivider, MenuDivider,
MenuItem, MenuItem,
MenuList, MenuList,
Tab,
TabList,
TabPanel,
TabPanels,
Text, Text,
useToast, useToast,
} from '@chakra-ui/react'; } from '@chakra-ui/react';
@ -28,6 +32,8 @@ import { kwm2AddKey, kwm2ClearKeys, kwm2ImportKeys } from '../settingsSlice';
import { selectStagingKWMv2Keys } from '../settingsSelector'; import { selectStagingKWMv2Keys } from '../settingsSelector';
import { KWMv2EKeyItem } from './KWMv2/KWMv2EKeyItem'; import { KWMv2EKeyItem } from './KWMv2/KWMv2EKeyItem';
import type { StagingKWMv2Key } from '../keyFormats'; import type { StagingKWMv2Key } from '../keyFormats';
import { InstructionsPC } from './KWMv2/InstructionsPC';
import { AndroidADBPullInstruction } from '~/components/AndroidADBPullInstruction/AndroidADBPullInstruction';
export function PanelKWMv2Key() { export function PanelKWMv2Key() {
const toast = useToast(); const toast = useToast();
@ -39,7 +45,7 @@ export function PanelKWMv2Key() {
const clearAll = () => dispatch(kwm2ClearKeys()); const clearAll = () => dispatch(kwm2ClearKeys());
const handleSecretImport = async (file: File) => { const handleSecretImport = async (file: File) => {
let keys: Omit<StagingKWMv2Key, 'id'>[] | null = null; let keys: Omit<StagingKWMv2Key, 'id'>[] | null = null;
if (/cn\.kuwo\.player\.mmkv\.defaultconfig/i.test(file.name)) { if (/cn\.kuwo\.player\.mmkv/i.test(file.name)) {
const fileBuffer = await file.arrayBuffer(); const fileBuffer = await file.arrayBuffer();
keys = MMKVParser.parseKuwoEKey(new DataView(fileBuffer)); keys = MMKVParser.parseKuwoEKey(new DataView(fileBuffer));
} }
@ -108,7 +114,21 @@ export function PanelKWMv2Key() {
onClose={() => setShowImportModal(false)} onClose={() => setShowImportModal(false)}
onImport={handleSecretImport} onImport={handleSecretImport}
> >
<TabList>
<Tab></Tab>
<Tab>Windows</Tab>
</TabList>
<TabPanels flex={1} overflow="auto">
<TabPanel>
<AndroidADBPullInstruction
dir="/data/data/cn.kuwo.player/files/mmkv"
file="cn.kuwo.player.mmkv.defaultconfig"
/>
</TabPanel>
<TabPanel>
<InstructionsPC />
</TabPanel>
</TabPanels>
</ImportSecretModal> </ImportSecretModal>
</Flex> </Flex>
); );

View File

@ -34,10 +34,10 @@ import { StagingQMCv2Key } from '../keyFormats';
import { DatabaseKeyExtractor } from '~/util/DatabaseKeyExtractor'; import { DatabaseKeyExtractor } from '~/util/DatabaseKeyExtractor';
import { MMKVParser } from '~/util/MMKVParser'; import { MMKVParser } from '~/util/MMKVParser';
import { getFileName } from '~/util/pathHelper'; import { getFileName } from '~/util/pathHelper';
import { InstructionsAndroid } from './QMCv2/InstructionsAndroid';
import { InstructionsIOS } from './QMCv2/InstructionsIOS'; import { InstructionsIOS } from './QMCv2/InstructionsIOS';
import { InstructionsMac } from './QMCv2/InstructionsMac'; import { InstructionsMac } from './QMCv2/InstructionsMac';
import { InstructionsPC } from './QMCv2/InstructionsPC'; import { InstructionsPC } from './QMCv2/InstructionsPC';
import { AndroidADBPullInstruction } from '~/components/AndroidADBPullInstruction/AndroidADBPullInstruction';
export function PanelQMCv2Key() { export function PanelQMCv2Key() {
const toast = useToast(); const toast = useToast();
@ -172,7 +172,7 @@ export function PanelQMCv2Key() {
</TabList> </TabList>
<TabPanels flex={1} overflow="auto"> <TabPanels flex={1} overflow="auto">
<TabPanel> <TabPanel>
<InstructionsAndroid /> <AndroidADBPullInstruction dir="/data/data/com.tencent.qqmusic/databases" file="player_process_db" />
</TabPanel> </TabPanel>
<TabPanel> <TabPanel>
<InstructionsIOS /> <InstructionsIOS />

View File

@ -1,2 +0,0 @@
sh adb shell su -c "cat '/data/data/com.tencent.qqmusic/databases/player_process_db' | gzip | base64" \
| base64 -d | gzip -d player_process_db