From 9e8fecd3ca121c3acaec6cc0450ff2ab6a57d3e5 Mon Sep 17 00:00:00 2001 From: Denis Andrasec Date: Mon, 9 Dec 2024 14:32:01 +0100 Subject: [PATCH] update template, check already added to pubspec --- src/flutter/code-tools.ts | 86 +++++++++++++++++++++++++++++++-------- src/flutter/templates.ts | 2 +- 2 files changed, 69 insertions(+), 19 deletions(-) diff --git a/src/flutter/code-tools.ts b/src/flutter/code-tools.ts index 9073d124..1d1ec057 100644 --- a/src/flutter/code-tools.ts +++ b/src/flutter/code-tools.ts @@ -47,26 +47,76 @@ export async function patchPubspec(pubspecFile: string | null, project: string, } let pubspecContent = fs.readFileSync(pubspecFile, 'utf8'); - const dependenciesIndex = getDependenciesLocation(pubspecContent); - - // TODO: Check if already added sentry: - - const sentryFlutterVersion = await fetchSdkVersion("sentry.dart.flutter") ?? "any"; - pubspecContent = pubspecContent.slice(0, dependenciesIndex) + - ` sentry_flutter: ${sentryFlutterVersion ? `^${sentryFlutterVersion}` : "any"}\n` + - pubspecContent.slice(dependenciesIndex); - - const devDependenciesIndex = getDevDependenciesLocation(pubspecContent); - - // TODO: Check if already added sentry-dart-plugin: - pubspecContent = pubspecContent.slice(0, devDependenciesIndex) + - ' sentry_dart_plugin: any\n' + // TODO: There is no sentry dart plugin in https://release-registry.services.sentry.io/sdks - pubspecContent.slice(devDependenciesIndex); + if (!pubspecContent.includes('sentry_flutter:')) { + const dependenciesIndex = getDependenciesLocation(pubspecContent); + + const sentryDartFlutterVersion = await fetchSdkVersion("sentry.dart.flutter") ?? "any"; + pubspecContent = pubspecContent.slice(0, dependenciesIndex) + + ` sentry_flutter: ${sentryDartFlutterVersion ? `^${sentryDartFlutterVersion}` : "any"}\n` + + pubspecContent.slice(dependenciesIndex); + + clack.log.success( + chalk.greenBright( + `${chalk.bold( + 'sentry_flutter', + )} added to pubspec.yaml`, + ), + ); + } else { + clack.log.success( + chalk.greenBright( + `${chalk.bold( + 'sentry_flutter', + )} is already included in pubspec.yaml`, + ), + ); + } + + if (!pubspecContent.includes('sentry_dart_plugin:')) { + const devDependenciesIndex = getDevDependenciesLocation(pubspecContent); + + const sentryDartPluginVersion = await fetchSdkVersion("sentry.dart.plugin") ?? "any"; + pubspecContent = pubspecContent.slice(0, devDependenciesIndex) + + ` sentry_dart_plugin: ${sentryDartPluginVersion ? `^${sentryDartPluginVersion}` : "any"}\n` + + pubspecContent.slice(devDependenciesIndex); - // TODO: Check if already added sentry: + clack.log.success( + chalk.greenBright( + `${chalk.bold( + 'sentry_dart_plugin', + )} added to pubspec.yaml`, + ), + ); + } else { + clack.log.success( + chalk.greenBright( + `${chalk.bold( + 'sentry_dart_plugin', + )} is already included in pubspec.yaml`, + ), + ); + } + + if (!pubspecContent.includes('sentry:')) { + pubspecContent += '\n' + pubspecContent += pubspecOptions(project, org); - pubspecContent += '\n' - pubspecContent += pubspecOptions(project, org); + clack.log.success( + chalk.greenBright( + `${chalk.bold( + 'sentry plugin configuration', + )} added to pubspec.yaml`, + ), + ); + } else { + clack.log.success( + chalk.greenBright( + `${chalk.bold( + 'sentry plugin configuration', + )} is already included in pubspec.yaml`, + ), + ); + } fs.writeFileSync(pubspecFile, pubspecContent, 'utf8'); diff --git a/src/flutter/templates.ts b/src/flutter/templates.ts index 23a36df6..2cef55a8 100644 --- a/src/flutter/templates.ts +++ b/src/flutter/templates.ts @@ -28,6 +28,6 @@ export function initSnippet(dsn: string, runApp: string): string { appRunner: () => runApp(${runApp}), ); // TODO: Remove this line after sending the first sample event to sentry. - Sentry.captureMessage('This is a sample exception.'); + await Sentry.captureMessage('This is a sample exception.'); ` }