Skip to content

Commit

Permalink
wip imap import
Browse files Browse the repository at this point in the history
  • Loading branch information
tuta-sudipg committed Oct 21, 2024
1 parent 18ad261 commit 5794bd2
Show file tree
Hide file tree
Showing 86 changed files with 2,899 additions and 24 deletions.
15 changes: 14 additions & 1 deletion buildSrc/DesktopBuilder.js
Original file line number Diff line number Diff line change
Expand Up @@ -121,7 +121,10 @@ async function rollupDesktop(dirname, outDir, version, platform, architecture, d
input: [path.join(dirname, "src/common/desktop/DesktopMain.ts"), path.join(dirname, "src/common/desktop/sqlworker.ts")],
// some transitive dep of a transitive dev-dep requires https://www.npmjs.com/package/url
// which rollup for some reason won't distinguish from the node builtin.
external: ["url", "util", "path", "fs", "os", "http", "https", "crypto", "child_process", "electron"],
external: (id, parent, isResolved) => {
if (parent != null && parent.endsWith("node-mimimi/dist/binding.cjs")) return true
return ["url", "util", "path", "fs", "os", "http", "https", "crypto", "child_process", "electron"].includes(id)
},
preserveEntrySignatures: false,
plugins: [
copyNativeModulePlugin({
Expand All @@ -131,6 +134,16 @@ async function rollupDesktop(dirname, outDir, version, platform, architecture, d
architecture,
nodeModule: "better-sqlite3",
}),
{
// todo: this needs to work everywhere
name: "copy-mimimi-plugin",
async buildStart() {
const normalDst = path.join(path.normalize("./build/desktop/"), "node-mimimi.linux-x64-gnu.node")
const dstDir = path.dirname(normalDst)
await fs.promises.mkdir(dstDir, { recursive: true })
await fs.promises.copyFile("./packages/node-mimimi/dist/node-mimimi.linux-x64-gnu.node", normalDst)
},
},
typescript({
tsconfig: "tsconfig.json",
outDir,
Expand Down
10 changes: 7 additions & 3 deletions buildSrc/DevBuild.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ import { build as esbuild } from "esbuild"
import { getTutanotaAppVersion, runStep, writeFile } from "./buildUtils.js"
import "zx/globals"
import * as env from "./env.js"
import { externalTranslationsPlugin, libDeps, preludeEnvPlugin, sqliteNativePlugin } from "./esbuildUtils.js"
import { externalTranslationsPlugin, libDeps, mimimiNativePlugin, preludeEnvPlugin, sqliteNativePlugin } from "./esbuildUtils.js"
import { fileURLToPath } from "node:url"
import * as LaunchHtml from "./LaunchHtml.js"
import os from "node:os"
Expand Down Expand Up @@ -173,9 +173,9 @@ async function buildDesktopPart({ version, app }) {
format: "cjs",
sourcemap: "linked",
platform: "node",
external: ["electron"],
external: ["electron", "*.node"],
banner: {
js: `globalThis.buildOptions = globalThis.buildOptions ?? {}
js: `globalThis.buildOptions = globalThis.buildOptions ?? {}
globalThis.buildOptions.sqliteNativePath = "./better-sqlite3.node";`,
},
plugins: [
Expand All @@ -187,6 +187,10 @@ globalThis.buildOptions.sqliteNativePath = "./better-sqlite3.node";`,
architecture: process.arch,
nativeBindingPath: "./better_sqlite3.node",
}),
mimimiNativePlugin({
dstPath: `./${buildDir}/desktop/`,
platform: process.platform,
}),
preludeEnvPlugin(env.create({ staticUrl: null, version, mode: "Desktop", dist: false, domainConfigs })),
externalTranslationsPlugin(),
],
Expand Down
37 changes: 36 additions & 1 deletion buildSrc/esbuildUtils.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ import { aliasPath as esbuildPluginAliasPath } from "esbuild-plugin-alias-path"

/**
* Little plugin that obtains compiled better-sqlite3, copies it to dstPath and sets the path to nativeBindingPath.
* We do not use default file loader from esbuild, it is much simpler and reliable to do it manually and it doesn't work for dynamic import (like in this case)
* We do not use default file loader from esbuild, it is much simpler and reliable to do it manually, and it doesn't work for dynamic import (like in this case)
* anyway.
* It will also replace `buildOptions.sqliteNativePath` with the nativeBindingPath
*/
Expand Down Expand Up @@ -37,6 +37,41 @@ export function sqliteNativePlugin({ environment, dstPath, nativeBindingPath, pl
}
}

export function mimimiNativePlugin({ dstPath, platform }) {
return {
name: "mimimi-native-plugin",
setup(build) {
const options = build.initialOptions
options.define = options.define ?? {}

build.onStart(async () => {
let nativeBinaryName
switch (platform) {
case "linux":
nativeBinaryName = "node-mimimi.linux-x64-gnu.node"
break
case "win32":
nativeBinaryName = "node-mimimi.win32-x64-msvc.node"
break
case "darwin":
nativeBinaryName = "node-mimimi.darwin-universal.node"
break
default:
throw Error(`could not find node-mimimi binary: platform ${platform} is unknown`)
}

// Replace mentions of buildOptions.mimimiNativePath with the actual path
options.define["buildOptions.mimimiNativePath"] = `"./${nativeBinaryName}"`

const nativeBinarySourcePath = path.join(process.cwd(), "./packages/node-mimimi/dist", nativeBinaryName)

await fs.promises.mkdir(path.dirname(dstPath), { recursive: true })
await fs.promises.copyFile(nativeBinarySourcePath, path.join(process.cwd(), dstPath, nativeBinaryName))
})
},
}
}

/** Little plugin that replaces imports for libs from dependencyMap with their prebuilt versions in libs directory. */
export function libDeps(prefix = ".") {
const absoluteDependencyMap = Object.fromEntries(
Expand Down
4 changes: 2 additions & 2 deletions buildSrc/packageBuilderFunctions.js
Original file line number Diff line number Diff line change
Expand Up @@ -12,13 +12,13 @@ export async function buildRuntimePackages() {
// tsconfig is rather JSON5, if it becomes a problem switch to JSON5 parser here
const tsconfig = JSON.parse(await fs.readFile("tsconfig.json", { encoding: "utf-8" }))
const packagePaths = tsconfig.references.map((ref) => ref.path)
await $`npx tsc -b ${packagePaths}`
await Promise.all(packagePaths.map((dir) => $`cd ${dir} && npm run build`))
}

/**
* Build all packages in packages directory.
*/
export async function buildPackages(pathPrefix = ".") {
const packages = await glob(`${pathPrefix}/packages/*`, { deep: 1, onlyDirectories: true })
await $`npx tsc -b ${packages}`
await Promise.all(packages.map((dir) => $`cd ${dir} && npm run build`))
}
34 changes: 34 additions & 0 deletions ipc-schema/facades/ImapImportSystemFacade.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
{
"name": "ImapImportSystemFacade",
"type": "facade",
"senders": ["web"],
"receivers": ["desktop"],
"doc": "Facade implemented by the native desktop client starting and stopping an IMAP import.",
"methods": {
"setup": {
"doc": "Initializing the IMAP import.",
"arg": [
{
"apiUrl": "string"
},
{
"unencryptedTutaCredentials": "UnencryptedCredentials"
},
{
"imapCredentials": "ImapCredentials"
}
],
"ret": "void"
},
"startImport": {
"doc": "Start the IMAP import.",
"arg": [],
"ret": "void"
},
"stopImport": {
"doc": "Stop a running IMAP import.",
"arg": [],
"ret": "void"
}
}
}
7 changes: 7 additions & 0 deletions ipc-schema/types/ImapCredentials.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
{
"name": "ImapCredentials",
"type": "typeref",
"location": {
"typescript": "../packages/node-mimimi/dist/binding.js"
}
}
2 changes: 1 addition & 1 deletion ipc-schema/types/MailBundle.json
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,6 @@
"name": "MailBundle",
"type": "typeref",
"location": {
"typescript": "../src/mail-app/mail/export/Bundler.js"
"typescript": "../src/common/mailFunctionality/SharedMailUtils.js"
}
}
7 changes: 7 additions & 0 deletions ipc-schema/types/TutaCredentials.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
{
"name": "TutaCredentials",
"type": "typeref",
"location": {
"typescript": "../packages/node-mimimi/dist/binding.js"
}
}
48 changes: 48 additions & 0 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 2 additions & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,8 @@
"fix": "npm run style:fix && npm run lint:fix"
},
"dependencies": {
"@napi-rs/cli": "^2.18.4",
"@tutao/node-mimimi": "244.240923.0",
"@tutao/oxmsg": "0.0.9-beta.0",
"@tutao/tuta-wasm-loader": "250.241018.0",
"@tutao/tutanota-crypto": "250.241018.0",
Expand Down
2 changes: 2 additions & 0 deletions packages/node-mimimi/.cargo/config.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
[target.x86_64-pc-windows-msvc]
rustflags = ["-C", "target-feature=+crt-static"]
Loading

0 comments on commit 5794bd2

Please sign in to comment.