mirror of
https://github.com/spacedriveapp/spacedrive.git
synced 2026-02-20 07:37:26 -05:00
* Update rspc, prisma-client-rust, axum and tanstack-query - Deleted some unused examples and fully commented out frontend code - Implement many changes required due to the updates - Update most rust dependencies * Re-enable p2p * Fix server * Auto format * Fix injected script format - Update some github actions - Update pnpm lock file * Fix devtools showing up when app opens - Fix million complaining about Sparkles component * Fix sd-server * Fix and improve thumbnails rendering - Fix core always saying a new thumbnail was generated even for files that it skiped thumbnail generation - Rewrite FileThumb and improve related components * Ignore tmp files when running prettier * Improve FileThumb component performance - Rework useExplorerDraggable and useExplorerItemData hooks due to reduce unecessary re-renders * More fixes for thumb component - A couple of minor performance improvements to frontend code * auto format * Fix Thumbnail and QuickPreview * Fix logic for when to show 'fail to load original' error message in QuickPreview - Updated prisma-client-rust, libp2p, tauri, tauri-specta, rspc and hyper * Fix type checking - Format scripts * Add script prettier config * Fix serde missing feature - Use rust-libp2p spacedrive fork again - Update rspc * Autoformat + fix pnpm lock * Fix thumbnail first load again * Autoformat * autoformat * Fix rust-libp2p fork url again? * Remove usePathsInfiniteQuery hook * Update tauri 2.0.6
220 lines
6.3 KiB
JavaScript
Executable File
220 lines
6.3 KiB
JavaScript
Executable File
#!/usr/bin/env node
|
|
import * as fs from 'node:fs/promises'
|
|
import * as path from 'node:path'
|
|
import { env, exit, umask } from 'node:process'
|
|
import { fileURLToPath } from 'node:url'
|
|
|
|
import { extractTo } from 'archive-wasm/src/fs.mjs'
|
|
import * as _mustache from 'mustache'
|
|
import { parse as parseTOML } from 'smol-toml'
|
|
|
|
import { getConst, NATIVE_DEPS_ASSETS, NATIVE_DEPS_URL } from './utils/consts.mjs'
|
|
import { get } from './utils/fetch.mjs'
|
|
import { getMachineId } from './utils/machineId.mjs'
|
|
import { getRustTargetList } from './utils/rustup.mjs'
|
|
import { symlinkSharedLibsLinux, symlinkSharedLibsMacOS } from './utils/shared.mjs'
|
|
import { spinTask } from './utils/spinner.mjs'
|
|
import { which } from './utils/which.mjs'
|
|
|
|
if (/^(msys|mingw|cygwin)$/i.test(env.OSTYPE ?? '')) {
|
|
console.error(
|
|
'Bash for windows is not supported, please interact with this repo from Powershell or CMD'
|
|
)
|
|
exit(255)
|
|
}
|
|
|
|
// @ts-expect-error
|
|
const mustache = /** @type {import("mustache")} */ (_mustache.default)
|
|
|
|
// Limit file permissions
|
|
umask(0o026)
|
|
|
|
const __debug = env.NODE_ENV === 'debug'
|
|
const __filename = fileURLToPath(import.meta.url)
|
|
const __dirname = path.dirname(__filename)
|
|
|
|
// NOTE: Must point to package root path
|
|
const __root = path.resolve(path.join(__dirname, '..'))
|
|
|
|
const extractOpts = {
|
|
chmod: 0o600,
|
|
sizeLimit: 256n * 1024n * 1024n,
|
|
recursive: true,
|
|
overwrite: true,
|
|
}
|
|
|
|
const bugWarn =
|
|
'This is probably a bug, please open a issue with you system info at: ' +
|
|
'https://github.com/spacedriveapp/spacedrive/issues/new/choose'
|
|
|
|
// Current machine identifiers
|
|
const machineId = getMachineId()
|
|
|
|
// Basic dependeny check
|
|
if ((await Promise.all([which('cargo'), which('rustc'), which('pnpm')])).some(found => !found)) {
|
|
console.error(`Basic dependencies missing.
|
|
Make sure you have rust and pnpm installed:
|
|
https://rustup.rs
|
|
https://pnpm.io/installation
|
|
|
|
Also that you have run the setup script:
|
|
packages/scripts/${machineId[0] === 'Windows_NT' ? 'setup.ps1' : 'setup.sh'}
|
|
`)
|
|
}
|
|
|
|
// Directory where the native deps will be downloaded
|
|
const nativeDeps = path.join(__root, 'apps', '.deps')
|
|
const mobileNativeDeps = path.join(__root, 'apps', 'mobile', '.deps')
|
|
await fs.rm(nativeDeps, { force: true, recursive: true })
|
|
await fs.mkdir(nativeDeps, { mode: 0o750, recursive: true })
|
|
|
|
// Native deps for desktop app
|
|
try {
|
|
console.log('Downloading desktop native dependencies...')
|
|
|
|
const assetName = getConst(NATIVE_DEPS_ASSETS, machineId)
|
|
if (assetName == null) throw new Error('NO_ASSET')
|
|
|
|
const archiveData = await spinTask(
|
|
get((__debug && env.NATIVE_DEPS_URL) || `${NATIVE_DEPS_URL}/${assetName}`)
|
|
)
|
|
|
|
console.log(`Extracting native dependencies...`)
|
|
await spinTask(extractTo(archiveData, nativeDeps, extractOpts))
|
|
} catch (e) {
|
|
console.error(`Failed to download native dependencies.\n${bugWarn}`)
|
|
if (__debug) console.error(e)
|
|
exit(1)
|
|
}
|
|
|
|
const rustTargets = await getRustTargetList()
|
|
const iosTargets = {
|
|
'aarch64-apple-ios': NATIVE_DEPS_ASSETS.IOS.ios.aarch64,
|
|
'aarch64-apple-ios-sim': NATIVE_DEPS_ASSETS.IOS.iossim.aarch64,
|
|
'x86_64-apple-ios': NATIVE_DEPS_ASSETS.IOS.iossim.x86_64,
|
|
}
|
|
|
|
// Native deps for mobile
|
|
try {
|
|
const mobileTargets = /** @type {Record<string, string>} */ {}
|
|
|
|
if (machineId[0] === 'Darwin')
|
|
// iOS is only supported on macOS
|
|
Object.assign(mobileTargets, iosTargets)
|
|
|
|
for (const [rustTarget, nativeTarget] of Object.entries(mobileTargets)) {
|
|
if (!rustTargets.has(rustTarget)) continue
|
|
console.log(`Downloading mobile native dependencies for ${nativeTarget}...`)
|
|
|
|
const specificMobileNativeDeps = path.join(mobileNativeDeps, rustTarget)
|
|
await fs.rm(specificMobileNativeDeps, { force: true, recursive: true })
|
|
await fs.mkdir(specificMobileNativeDeps, { mode: 0o750, recursive: true })
|
|
|
|
const archiveData = await spinTask(
|
|
get(
|
|
(__debug &&
|
|
env[`NATIVE_DEPS_${rustTarget.replaceAll('-', '_').toUpperCase()}_URL`]) ||
|
|
`${NATIVE_DEPS_URL}/${nativeTarget}`
|
|
)
|
|
)
|
|
|
|
console.log(`Extracting native dependencies...`)
|
|
await spinTask(extractTo(archiveData, specificMobileNativeDeps, extractOpts))
|
|
}
|
|
} catch (e) {
|
|
console.error(`Failed to download native dependencies for mobile.\n${bugWarn}`)
|
|
if (__debug) console.error(e)
|
|
exit(1)
|
|
}
|
|
|
|
// Extra OS specific setup
|
|
try {
|
|
if (machineId[0] === 'Linux') {
|
|
console.log(`Symlink shared libs...`)
|
|
await spinTask(
|
|
symlinkSharedLibsLinux(__root, nativeDeps).catch(e => {
|
|
console.error(`Failed to symlink shared libs.\n${bugWarn}`)
|
|
throw e
|
|
})
|
|
)
|
|
} else if (machineId[0] === 'Darwin') {
|
|
// This is still required due to how ffmpeg-sys-next builds script works
|
|
console.log(`Symlink shared libs...`)
|
|
await spinTask(
|
|
symlinkSharedLibsMacOS(__root, nativeDeps).catch(e => {
|
|
console.error(`Failed to symlink shared libs.\n${bugWarn}`)
|
|
throw e
|
|
})
|
|
)
|
|
}
|
|
} catch (error) {
|
|
if (__debug) console.error(error)
|
|
exit(1)
|
|
}
|
|
|
|
// Generate .cargo/config.toml
|
|
console.log('Generating cargo config...')
|
|
try {
|
|
let isWin = false
|
|
let isMacOS = false
|
|
let isLinux = false
|
|
/** @type {boolean | { linker: string }} */
|
|
let hasLLD = false
|
|
switch (machineId[0]) {
|
|
case 'Linux':
|
|
isLinux = true
|
|
if (await which('clang')) {
|
|
if (await which('mold')) {
|
|
hasLLD = { linker: 'mold' }
|
|
} else if (await which('lld')) {
|
|
hasLLD = { linker: 'lld' }
|
|
}
|
|
}
|
|
break
|
|
case 'Darwin':
|
|
isMacOS = true
|
|
break
|
|
case 'Windows_NT':
|
|
isWin = true
|
|
hasLLD = await which('lld-link')
|
|
break
|
|
}
|
|
|
|
const configData = mustache
|
|
.render(
|
|
await fs.readFile(path.join(__root, '.cargo', 'config.toml.mustache'), {
|
|
encoding: 'utf8',
|
|
}),
|
|
{
|
|
isWin,
|
|
hasiOS: Object.keys(iosTargets).some(target => rustTargets.has(target)),
|
|
isMacOS,
|
|
isLinux,
|
|
// Escape windows path separator to be compatible with TOML parsing
|
|
protoc: path
|
|
.join(
|
|
nativeDeps,
|
|
'bin',
|
|
machineId[0] === 'Windows_NT' ? 'protoc.exe' : 'protoc'
|
|
)
|
|
.replaceAll('\\', '\\\\'),
|
|
nativeDeps: nativeDeps.replaceAll('\\', '\\\\'),
|
|
mobileNativeDeps: mobileNativeDeps.replaceAll('\\', '\\\\'),
|
|
hasLLD,
|
|
}
|
|
)
|
|
.replace(/\n\n+/g, '\n')
|
|
|
|
// Validate generated TOML
|
|
parseTOML(configData)
|
|
|
|
await fs.writeFile(path.join(__root, '.cargo', 'config.toml'), configData, {
|
|
mode: 0o751,
|
|
flag: 'w+',
|
|
})
|
|
} catch (error) {
|
|
console.error(`Failed to generate .cargo/config.toml.\n${bugWarn}`)
|
|
if (__debug) console.error(error)
|
|
exit(1)
|
|
}
|