mirror of
https://github.com/inventree/inventree-app.git
synced 2025-04-27 21:16:48 +00:00
Remove all sentry references
- Google play store already offers crash reporting...
This commit is contained in:
parent
161535c11c
commit
59585f72cf
3
.gitignore
vendored
3
.gitignore
vendored
@ -9,9 +9,6 @@
|
||||
.history
|
||||
.svn/
|
||||
|
||||
# Sentry API key
|
||||
lib/dsn.dart
|
||||
|
||||
# App signing key
|
||||
android/key.properties
|
||||
|
||||
|
@ -8,7 +8,7 @@ export "SYMROOT=${SOURCE_ROOT}/../build\ios"
|
||||
export "OTHER_LDFLAGS=$(inherited) -framework Flutter"
|
||||
export "FLUTTER_FRAMEWORK_DIR=C:\flutter\bin\cache\artifacts\engine\ios"
|
||||
export "FLUTTER_BUILD_NAME=0.1.0"
|
||||
export "FLUTTER_BUILD_NUMBER=0.1.0"
|
||||
export "FLUTTER_BUILD_NUMBER=3"
|
||||
export "DART_OBFUSCATION=false"
|
||||
export "TRACK_WIDGET_CREATION=false"
|
||||
export "TREE_SHAKE_ICONS=false"
|
||||
|
@ -211,7 +211,7 @@ class InvenTreeAPI {
|
||||
showTimeoutError(context);
|
||||
return null;
|
||||
} else {
|
||||
// Unknown error type - re-throw the error and Sentry will catch it
|
||||
// Unknown error type - re-throw
|
||||
throw error;
|
||||
}
|
||||
});
|
||||
|
@ -156,7 +156,7 @@ class InvenTreeModel {
|
||||
else if (e is TimeoutException) {
|
||||
showTimeoutError(context);
|
||||
} else {
|
||||
// Re-throw the error (Sentry will catch)
|
||||
// Re-throw the error
|
||||
throw e;
|
||||
}
|
||||
|
||||
@ -202,7 +202,7 @@ class InvenTreeModel {
|
||||
} else if (e is TimeoutException) {
|
||||
showTimeoutError(context);
|
||||
} else {
|
||||
// Re-throw the error, let Sentry report it
|
||||
// Re-throw the error
|
||||
throw e;
|
||||
}
|
||||
|
||||
@ -253,7 +253,7 @@ class InvenTreeModel {
|
||||
else if (e is TimeoutException) {
|
||||
showTimeoutError(context);
|
||||
} else {
|
||||
// Re-throw the error (handled by Sentry)
|
||||
// Re-throw the error
|
||||
throw e;
|
||||
}
|
||||
return null;
|
||||
@ -301,7 +301,7 @@ class InvenTreeModel {
|
||||
else if (e is TimeoutException) {
|
||||
showTimeoutError(context);
|
||||
} else {
|
||||
// Re-throw the error (Sentry will catch)
|
||||
// Re-throw the error
|
||||
throw e;
|
||||
}
|
||||
|
||||
|
@ -1,168 +0,0 @@
|
||||
import 'dart:io';
|
||||
|
||||
import 'package:device_info/device_info.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:font_awesome_flutter/font_awesome_flutter.dart';
|
||||
import 'package:package_info/package_info.dart';
|
||||
import 'package:sentry_flutter/sentry_flutter.dart';
|
||||
import 'package:one_context/one_context.dart';
|
||||
import 'package:flutter_gen/gen_l10n/app_localizations.dart';
|
||||
|
||||
import '../api.dart';
|
||||
|
||||
Future<Map<String, dynamic>> getDeviceInfo() async {
|
||||
|
||||
// Extract device information
|
||||
final DeviceInfoPlugin deviceInfo = DeviceInfoPlugin();
|
||||
|
||||
Map<String, dynamic> device_info = {};
|
||||
|
||||
// Extract some platform information
|
||||
if (Platform.isIOS) {
|
||||
final iosDeviceInfo = await deviceInfo.iosInfo;
|
||||
|
||||
device_info = {
|
||||
'name': iosDeviceInfo.name,
|
||||
'model': iosDeviceInfo.model,
|
||||
'systemName': iosDeviceInfo.systemName,
|
||||
'systemVersion': iosDeviceInfo.systemVersion,
|
||||
'localizedModel': iosDeviceInfo.localizedModel,
|
||||
'utsname': iosDeviceInfo.utsname.sysname,
|
||||
'identifierForVendor': iosDeviceInfo.identifierForVendor,
|
||||
'isPhysicalDevice': iosDeviceInfo.isPhysicalDevice,
|
||||
};
|
||||
|
||||
} else if (Platform.isAndroid) {
|
||||
final androidDeviceInfo = await deviceInfo.androidInfo;
|
||||
|
||||
device_info = {
|
||||
'type': androidDeviceInfo.type,
|
||||
'model': androidDeviceInfo.model,
|
||||
'device': androidDeviceInfo.device,
|
||||
'id': androidDeviceInfo.id,
|
||||
'androidId': androidDeviceInfo.androidId,
|
||||
'brand': androidDeviceInfo.brand,
|
||||
'display': androidDeviceInfo.display,
|
||||
'hardware': androidDeviceInfo.hardware,
|
||||
'manufacturer': androidDeviceInfo.manufacturer,
|
||||
'product': androidDeviceInfo.product,
|
||||
'version': androidDeviceInfo.version.release,
|
||||
'supported32BitAbis': androidDeviceInfo.supported32BitAbis,
|
||||
'supported64BitAbis': androidDeviceInfo.supported64BitAbis,
|
||||
'supportedAbis': androidDeviceInfo.supportedAbis,
|
||||
'isPhysicalDevice': androidDeviceInfo.isPhysicalDevice,
|
||||
};
|
||||
}
|
||||
|
||||
return device_info;
|
||||
}
|
||||
|
||||
|
||||
Map<String, dynamic> getServerInfo() => {
|
||||
"version": InvenTreeAPI().version,
|
||||
};
|
||||
|
||||
|
||||
Future<Map<String, dynamic>> getAppInfo() async {
|
||||
// Add app info
|
||||
final package_info = await PackageInfo.fromPlatform();
|
||||
|
||||
return {
|
||||
"name": package_info.appName,
|
||||
"build": package_info.buildNumber,
|
||||
"version": package_info.version,
|
||||
"package": package_info.packageName,
|
||||
};
|
||||
}
|
||||
|
||||
|
||||
bool isInDebugMode() {
|
||||
bool inDebugMode = false;
|
||||
|
||||
assert(inDebugMode = true);
|
||||
|
||||
return inDebugMode;
|
||||
}
|
||||
|
||||
Future<void> _uploadErrorReport(dynamic error, dynamic stackTrace) async {
|
||||
|
||||
// Errors thrown in development mode are unlikely to be interesting. You can
|
||||
// check if you are running in dev mode using an assertion and omit sending
|
||||
// the report.
|
||||
if (isInDebugMode()) {
|
||||
|
||||
print('In dev mode. Not sending report to Sentry.io.');
|
||||
return;
|
||||
}
|
||||
|
||||
final server_info = getServerInfo();
|
||||
final app_info = await getAppInfo();
|
||||
final device_info = await getDeviceInfo();
|
||||
|
||||
Sentry.configureScope((scope) {
|
||||
scope.setExtra("server", server_info);
|
||||
scope.setExtra("app", app_info);
|
||||
scope.setExtra("device", device_info);
|
||||
});
|
||||
|
||||
Sentry.captureException(error, stackTrace: stackTrace).catchError((error) {
|
||||
print("Error uploading information to Sentry.io:");
|
||||
print(error);
|
||||
}).then((response) {
|
||||
print("Uploaded information to Sentry.io : ${response.toString()}");
|
||||
});
|
||||
}
|
||||
|
||||
|
||||
Future<void> sentryReportError(dynamic error, dynamic stackTrace) async {
|
||||
|
||||
print('Intercepted error: $error');
|
||||
print(stackTrace);
|
||||
|
||||
await OneContext().showDialog(
|
||||
builder: (context) => AlertDialog(
|
||||
title: ListTile(
|
||||
title: Text(I18N.of(OneContext().context).error),
|
||||
leading: FaIcon(FontAwesomeIcons.exclamationCircle),
|
||||
subtitle: Text("An error occurred"),
|
||||
),
|
||||
actions: [
|
||||
FlatButton(
|
||||
child: Text("Upload Error Report"),
|
||||
onPressed: () {
|
||||
_uploadErrorReport(error, stackTrace);
|
||||
OneContext().pop();
|
||||
},
|
||||
)
|
||||
],
|
||||
content: Text(error.toString()),
|
||||
)
|
||||
);
|
||||
|
||||
return;
|
||||
|
||||
}
|
||||
|
||||
|
||||
Future<bool> sentryReportMessage(String message) async {
|
||||
|
||||
final server_info = getServerInfo();
|
||||
final app_info = await getAppInfo();
|
||||
final device_info = await getDeviceInfo();
|
||||
|
||||
print("Sending user message to Sentry");
|
||||
|
||||
Sentry.configureScope((scope) {
|
||||
scope.setExtra("server", server_info);
|
||||
scope.setExtra("app", app_info);
|
||||
scope.setExtra("device", device_info);
|
||||
});
|
||||
|
||||
final sentryId = await Sentry.captureMessage(message).catchError((error) {
|
||||
print("Error uploading sentry messages...");
|
||||
print(error);
|
||||
return null;
|
||||
});
|
||||
|
||||
return sentryId != null;
|
||||
}
|
@ -447,7 +447,7 @@ class InvenTreeStockItem extends InvenTreeModel {
|
||||
error.toString()
|
||||
);
|
||||
} else {
|
||||
// Re-throw the error, let sentry handle it!
|
||||
// Re-throw the error
|
||||
throw error;
|
||||
}
|
||||
|
||||
|
@ -1,7 +1,3 @@
|
||||
import 'dart:async';
|
||||
import 'dart:io';
|
||||
|
||||
import 'package:InvenTree/inventree/sentry.dart';
|
||||
import 'package:flutter_localizations/flutter_localizations.dart';
|
||||
import 'package:flutter_gen/gen_l10n/app_localizations.dart';
|
||||
|
||||
@ -10,42 +6,11 @@ import 'package:flutter/cupertino.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:one_context/one_context.dart';
|
||||
|
||||
import 'dsn.dart';
|
||||
|
||||
import 'package:sentry_flutter/sentry_flutter.dart';
|
||||
|
||||
|
||||
void main() async {
|
||||
|
||||
|
||||
await Sentry.init((options) {
|
||||
options.dsn = SENTRY_DSN_KEY;
|
||||
},
|
||||
//appRunner: () => runApp(InvenTreeApp())
|
||||
);
|
||||
|
||||
await runZonedGuarded<Future<void>>(() async {
|
||||
|
||||
WidgetsFlutterBinding.ensureInitialized();
|
||||
|
||||
// This captures errors reported by the Flutter framework.
|
||||
FlutterError.onError = (FlutterErrorDetails details) async {
|
||||
if (isInDebugMode()) {
|
||||
// In development mode simply print to console.
|
||||
FlutterError.dumpErrorToConsole(details);
|
||||
} else {
|
||||
// In production mode report to the application zone to report to
|
||||
// Sentry.
|
||||
Zone.current.handleUncaughtError(details.exception, details.stack);
|
||||
}
|
||||
};
|
||||
|
||||
runApp(InvenTreeApp());
|
||||
|
||||
}, (Object error, StackTrace stackTrace) {
|
||||
sentryReportError(error, stackTrace);
|
||||
});
|
||||
|
||||
}
|
||||
|
||||
class InvenTreeApp extends StatelessWidget {
|
||||
|
@ -1,14 +1,9 @@
|
||||
import 'package:InvenTree/inventree/sentry.dart';
|
||||
import 'package:InvenTree/settings/about.dart';
|
||||
import 'package:InvenTree/settings/login.dart';
|
||||
import 'package:InvenTree/user_profile.dart';
|
||||
import 'package:InvenTree/widget/dialogs.dart';
|
||||
import 'package:InvenTree/widget/snacks.dart';
|
||||
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:flutter/services.dart';
|
||||
import 'package:font_awesome_flutter/font_awesome_flutter.dart';
|
||||
import 'package:sentry_flutter/sentry_flutter.dart';
|
||||
import 'package:flutter_gen/gen_l10n/app_localizations.dart';
|
||||
import 'package:url_launcher/url_launcher.dart';
|
||||
|
||||
@ -28,7 +23,6 @@ class InvenTreeSettingsWidget extends StatefulWidget {
|
||||
class _InvenTreeSettingsState extends State<InvenTreeSettingsWidget> {
|
||||
|
||||
final _scaffoldKey = GlobalKey<ScaffoldState>();
|
||||
final _bugKey = GlobalKey<FormState>();
|
||||
|
||||
final String docsUrl = "https://inventree.readthedocs.io/en/latest/app/app/";
|
||||
|
||||
@ -66,12 +60,6 @@ class _InvenTreeSettingsState extends State<InvenTreeSettingsWidget> {
|
||||
},
|
||||
),
|
||||
|
||||
ListTile(
|
||||
title: Text(I18N.of(context).reportBug),
|
||||
subtitle: Text("Report bug or suggest new feature"),
|
||||
leading: FaIcon(FontAwesomeIcons.bug),
|
||||
onTap: _reportBug,
|
||||
),
|
||||
]
|
||||
).toList()
|
||||
)
|
||||
@ -100,41 +88,4 @@ class _InvenTreeSettingsState extends State<InvenTreeSettingsWidget> {
|
||||
MaterialPageRoute(builder: (context) => InvenTreeAboutWidget(info)));
|
||||
});
|
||||
}
|
||||
|
||||
void _sendReport(String message) async {
|
||||
|
||||
bool result = await sentryReportMessage(message);
|
||||
|
||||
if (result) {
|
||||
showSnackIcon(_scaffoldKey, "Uploaded report", success: true);
|
||||
} else {
|
||||
showSnackIcon(_scaffoldKey, "Report upload failed", success: false);
|
||||
}
|
||||
}
|
||||
|
||||
void _reportBug() async {
|
||||
|
||||
TextEditingController _controller = TextEditingController();
|
||||
|
||||
_controller.clear();
|
||||
|
||||
showFormDialog(
|
||||
"Upload Bug Report",
|
||||
key: _bugKey,
|
||||
callback: () {
|
||||
_sendReport(_controller.text);
|
||||
},
|
||||
fields: <Widget>[
|
||||
TextField(
|
||||
decoration: InputDecoration(
|
||||
hintText: "Enter bug report details",
|
||||
),
|
||||
keyboardType: TextInputType.multiline,
|
||||
maxLines: null,
|
||||
controller: _controller
|
||||
),
|
||||
]
|
||||
);
|
||||
|
||||
}
|
||||
}
|
14
pubspec.lock
14
pubspec.lock
@ -427,20 +427,6 @@ packages:
|
||||
url: "https://pub.dartlang.org"
|
||||
source: hosted
|
||||
version: "2.4.9"
|
||||
sentry:
|
||||
dependency: transitive
|
||||
description:
|
||||
name: sentry
|
||||
url: "https://pub.dartlang.org"
|
||||
source: hosted
|
||||
version: "4.0.4"
|
||||
sentry_flutter:
|
||||
dependency: "direct main"
|
||||
description:
|
||||
name: sentry_flutter
|
||||
url: "https://pub.dartlang.org"
|
||||
source: hosted
|
||||
version: "4.0.4"
|
||||
shared_preferences:
|
||||
dependency: transitive
|
||||
description:
|
||||
|
@ -7,7 +7,7 @@ description: InvenTree stock management
|
||||
# In iOS, build-name is used as CFBundleShortVersionString while build-number used as CFBundleVersion.
|
||||
# Read more about iOS versioning at
|
||||
# https://developer.apple.com/library/archive/documentation/General/Reference/InfoPlistKeyReference/Articles/CoreFoundationKeys.html
|
||||
version: 0.1.0+2
|
||||
version: 0.1.0+3
|
||||
|
||||
environment:
|
||||
sdk: ">=2.1.0 <3.0.0"
|
||||
@ -29,7 +29,6 @@ dependencies:
|
||||
device_info: ^1.0.0 # Information about the device
|
||||
font_awesome_flutter: ^8.8.1 # FontAwesome icon set
|
||||
flutter_speed_dial: ^1.2.5 # FAB menu elements
|
||||
sentry_flutter: ^4.0.4 # Error reporting
|
||||
flutter_typeahead: ^1.8.1 # Auto-complete input field
|
||||
image_picker: ^0.6.6 # Select or take photos
|
||||
url_launcher: ^5.7.10 # Open link in system browser
|
||||
|
Loading…
x
Reference in New Issue
Block a user