Skip to content

Commit

Permalink
Merge branch 'main' into feature/issue_71
Browse files Browse the repository at this point in the history
  • Loading branch information
edsonjab authored May 29, 2024
2 parents e15fbee + 53545e4 commit b5fd6f9
Show file tree
Hide file tree
Showing 8 changed files with 68 additions and 19 deletions.
39 changes: 39 additions & 0 deletions .github/workflows/create_jira.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
name: Create Jira Ticket

on:
issues:
types:
- opened

jobs:
create_jira:
name: Create Jira Ticket
runs-on: ubuntu-latest
environment: IssueTracker
steps:
- name: Checkout
uses: actions/checkout@master
- name: Login
uses: atlassian/gajira-login@master
env:
JIRA_BASE_URL: ${{ secrets.JIRA_BASE_URL }}
JIRA_USER_EMAIL: ${{ secrets.JIRA_USER_EMAIL }}
JIRA_API_TOKEN: ${{ secrets.JIRA_TOKEN }}
JIRA_EPIC_KEY: ${{ secrets.JIRA_EPIC_KEY }}
JIRA_PROJECT: ${{ secrets.JIRA_PROJECT }}

- name: Create
id: create
uses: atlassian/gajira-create@master
with:
project: ${{ secrets.JIRA_PROJECT }}
issuetype: Bug
summary: |
[${{ github.event.repository.name }}] (${{ github.event.issue.number }}): ${{ github.event.issue.title }}
description: |
Github Link: ${{ github.event.issue.html_url }}
${{ github.event.issue.body }}
fields: '{"parent": {"key": "${{ secrets.JIRA_EPIC_KEY }}"}}'

- name: Log created issue
run: echo "Issue ${{ steps.create.outputs.issue }} was created"
2 changes: 1 addition & 1 deletion example/test/widget_test.dart
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@
import 'package:flutter/material.dart';
import 'package:flutter_test/flutter_test.dart';

import 'package:segment_analytics_example/main.dart';
import 'package:analytics_example/main.dart';

void main() {
testWidgets('Verify Platform version', (WidgetTester tester) async {
Expand Down
5 changes: 3 additions & 2 deletions packages/core/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -112,7 +112,7 @@ You must pass at least the `writeKey`. Additional configuration options are list
### Client Options

| Name | Default | Description |
| --------------------------------- | ----------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------- |
| --------------------------------- | ----------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| `writeKey` **(REQUIRED)** | '' | Your Segment API key. |
| `debug` | false | When set to false, it will not generate any info logs. |
| `collectDeviceId` | false | Set to true to automatically collect the device ID from the DRM API on Android devices. |
Expand All @@ -124,9 +124,10 @@ You must pass at least the `writeKey`. Additional configuration options are list
| `trackDeeplinks` | false | Enable automatic tracking for when the user opens the app via a deep link. \*NOTE: when sending this flag, the sdk plugin_appsflyer will ignore [onAppOpenAttribution](https://github.com/AppsFlyerSDK/appsflyer-flutter-plugin/blob/master/doc/Guides.md#Unified-deep-linking) |
| `autoAddSegmentDestination` | true | Set to false to skip adding the SegmentDestination plugin |
| `defaultIntegrationSettings` | null | Plugin settings that will be used if the request to get the settings from Segment fails. |
| `maxBatchSize` | true | 100 | Maximum number of events to send to the API at once. |
| `maxBatchSize` | true | 100 Maximum number of events to send to the API at once. |
| `appStateStream` | null | Set to override the stream of application foreground or background events. |
| `requestFactory` | true | Set to override the factory to generate HTTP requests. Type: [RequestFactory](https://github.com/segmentio/analytics_flutter/blob/master/packages/core/lib/state.dart#L546) |
| `storageJson` | true | Enable or disable automatic the generation JSON files for the serialization library |

## Client methods

Expand Down
2 changes: 1 addition & 1 deletion packages/core/lib/analytics.dart
Original file line number Diff line number Diff line change
Expand Up @@ -59,7 +59,7 @@ class Analytics with ClientMethods {
{HTTPClient Function(Analytics)? httpClient})
: _state = StateManager(_store, System(true, false), config),
_timeline = Timeline() {
_state.init(error);
_state.init(error, config.storageJson!);

this.httpClient = httpClient == null ? HTTPClient(this) : httpClient(this);

Expand Down
2 changes: 1 addition & 1 deletion packages/core/lib/client.dart
Original file line number Diff line number Diff line change
Expand Up @@ -63,7 +63,7 @@ class ScreenObserver extends NavigatorObserver {

@override
void didPop(Route<dynamic> route, Route<dynamic>? previousRoute) {
final name = route.settings.name;
final name = previousRoute?.settings.name;
if (name != null) {
screenStreamController.add(name);
}
Expand Down
2 changes: 1 addition & 1 deletion packages/core/lib/plugins/queue_flushing_plugin.dart
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ class QueueFlushingPlugin extends UtilityPlugin {
_state = QueueState("queue_flushing_plugin", analytics.store,
(json) => eventFromJson(json));

_state!.init(analytics.error);
_state!.init(analytics.error, true);
}

@override
Expand Down
34 changes: 21 additions & 13 deletions packages/core/lib/state.dart
Original file line number Diff line number Diff line change
Expand Up @@ -28,11 +28,11 @@ class StateManager {
final DeepLinkDataState deepLinkData;
final UserInfoState userInfo;

void init(ErrorHandler errorHandler) {
filters.init(errorHandler);
deepLinkData.init(errorHandler);
userInfo.init(errorHandler);
context.init(errorHandler);
void init(ErrorHandler errorHandler, bool storageJson) {
filters.init(errorHandler, storageJson);
deepLinkData.init(errorHandler, storageJson);
userInfo.init(errorHandler, storageJson);
context.init(errorHandler, storageJson);
}

StateManager(Store store, System system, Configuration configuration)
Expand Down Expand Up @@ -159,15 +159,17 @@ abstract class PersistedState<T> implements AsyncStateNotifier<T> {
}
}

void init(ErrorHandler errorHandler) {
void init(ErrorHandler errorHandler, bool storageJson) {
this._errorHandler = errorHandler;
addListener((state) {
if (_persistance != null) {
_hasUpdated = true;
} else {
_persistance = _store
.setPersisted(_key, toJson(state))
.whenComplete(_whenPersistenceComplete);
_persistance = storageJson
? _store
.setPersisted(_key, toJson(state))
.whenComplete(_whenPersistenceComplete)
: null;
}
});
_store.ready.then<void>((_) async {
Expand All @@ -176,9 +178,11 @@ abstract class PersistedState<T> implements AsyncStateNotifier<T> {

if (rawV == null) {
final init = await _initialiser();
_persistance = _store
.setPersisted(_key, toJson(init))
.whenComplete(_whenPersistenceComplete);
_persistance = storageJson
? _store
.setPersisted(_key, toJson(init))
.whenComplete(_whenPersistenceComplete)
: null;
_notifier.nonNullState = init;
v = init;
} else {
Expand Down Expand Up @@ -522,6 +526,7 @@ class Configuration {
final RequestFactory? requestFactory;
final StreamSubscription<AppStatus> Function()? appStateStream;
final ErrorHandler? errorHandler;
final bool? storageJson;

final String? token;

Expand All @@ -539,7 +544,9 @@ class Configuration {
this.trackDeeplinks = false,
this.debug = false,
this.maxBatchSize,
this.token});
this.storageJson = true,
this.token
});
}

typedef ErrorHandler = void Function(Exception);
Expand All @@ -559,5 +566,6 @@ Configuration setFlushPolicies(
requestFactory: a.requestFactory,
trackApplicationLifecycleEvents: a.trackApplicationLifecycleEvents,
trackDeeplinks: a.trackDeeplinks,
storageJson: a.storageJson,
token: a.token);
}
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,7 @@ class PluginAdvertisingIdPlugin: FlutterPlugin, MethodCallHandler {

if (isLimitAdTrackingEnabled) {
result.success(null)
return
}

val id = advertisingInfo.id
Expand Down

0 comments on commit b5fd6f9

Please sign in to comment.