Changelog
All notable changes to this package will be documented in this file.
The format is based on Keep a Changelog and this project adheres to Semantic Versioning.
[5.1.1] - 2024-03-26
Added
- Added Apple Privacy Manifest
Changed
- Updated com.unity.services.coredependency to 1.12.5 which contains Apple Privacy Manifest
[5.1.0] - 2024-01-15
Added
- New RecordEvent(...)API which takes an instance of the newUnity.Services.Analytics.Eventclass- This enables you to codify custom event schemas in helper objects by making your own sub-classes of Event, to avoid the risks inherent in directly using plain dictionaries with string keys
- Event objects can also be pooled and reused because they are cleared immediately once their contents have been serialized
- A generic CustomEventclass is available which can be used in a flexible, dictionary-like way if you do not wish to make your own full sub-classes
 
- This enables you to codify custom event schemas in helper objects by making your own sub-classes of 
Deprecated
- Standard Event recording methods that take ...Parametershelper structs are now deprecated. Please replace them with the newEventsub-classes and use the newRecordEvent(...)method.- TransactionParameters -> TransactionEvent
- TransactionFailedParameters -> TransactionFailedEvent
- AdImpressionParameters -> AdImpressionEvent
- AcquisitionSourceParameters -> AcquisitionSourceEvent
 
- CustomData(...) methods
- Use RecordEvent(string) for events with no parameters
- Use RecordEvent(event) for events with parameters, by using CustomEvent or creating your own sub-class of Event to contain the parameters
 
Improved
- Improved the descriptions of some properties on the AdImpressionParametersclass
[5.0.2] - 2023-11-27
Fixed
- Analytics no longer throws a fatal exception on shutdown for builds made with 2023 editor versions
[5.0.1] - 2023-10-10
Fixed
- batteryLoad and deviceVolume values are no longer stale when included in some events
- Unity Player ID is no longer included twice in some events
- The Configure button in Unity Package Manager now correctly leads to the Analytics - Gaming Services page in Project Settings
- ClearBuffer(...) no longer throws ArgumentException if a player requests data deletion while an event batch upload is in progress
Improved
- Recording event timestamp and integer values is now slightly faster and generates fewer memory allocations
Changed
- The PrivacyUrlproperty now returns a link to the latest Game Player and App User Privacy Policy page, https://unity.com/legal/game-player-and-app-user-privacy-policy
[5.0.0] - 2023-06-29
Added
- New initialization and consent flow. Please see the migration guide for more information: https://docs.unity.com/ugs/en-us/manual/analytics/manual/sdk5-migration-guide
Deprecated
- The old initialization and consent flow should no longer be used and will be removed in a future version of the SDK. Please see the migration guide for more information: https://docs.unity.com/analytics/en/manual/AnalyticsSDK5MigrationGuide
Changed
- Updated com.unity.services.coredependency to 1.10.1
Breaking Changes
- The package no longer has a dependency on Newtonsoft.Json
- The package now has a dependency on the Unity JsonSerialize module (JsonUtility)
- A number of elements that were previously marked as Obsolete have now been removed
Fixed
- Analytics no longer blocks services initialization (UnityServices.InitializeAsync) if there is no internet connection
- It is now possible to opt in to data collection during a session where the player has previously opted out (requires migration to the new consent flow)
- Application.persistentDataPath is no longer requested on some platforms where access to the file system is denied by default
- Event buffer is now cleared on a wider variety of server responses
- Events are more eagerly cached to disk (if available) on shutdown to prevent data loss if game is closed while offline
- Data deletion requests are now sent using the custom user ID if one is set, instead of always using the installation ID
[4.4.2] - 2023-04-04
Fixed
- Revoking consent (opting out) now successfully uploads a data deletion request
Improved
- Recording events is now significantly faster and generates fewer memory allocations
[4.4.1] - 2023-03-15
Fixed
- Changing ExternalUserId now takes effect immediately, rather than after an unpredictable delay
[4.4.0] - 2023-03-02
Added
- CustomData method now supports IDictionary<string,object>, IList
Changed
- Events are now serialised immediately when recorded rather than as part of the upload process. This should alleviate any hitches that might have been experienced during upload (every 60 seconds)
- Updated com.unity.services.coredependency to 1.8.1
Fixed
- Custom user ID can now be changed at runtime (by updating UnityServices.ExternalUserId)
- Recording a single event that is too big to upload (over 4MB) no longer prevents any further events from being uploaded (event is immediately discarded with a warning)
- Session ID is now refreshed when application is paused for over 5 minutes (when Run In Background is false)
Deprecated
- The RecordEvent(Event event)API is no longer supported and will be removed in a future version
[4.3.0] - 2022-10-25
Added
- Added CustomData(string eventName) method for recording events that do not have any parameters
Fixed
- Issue where a single corrupt event could prevent all subsequent events from being sent
- NullReferenceException when passing null instead of a Dictionary of parameters to CustomData for an event that does not have any parameters
- NullReferenceException when passing null for the currency code to ConvertCurrencyToMinorUnits; it now throws an ArgumentNullException if the currency code is either null or empty
- Compiler error on 2020.1 editor versions
- Documentation comment on IAnalyticsService.Flush method to clarifybehaviour and usage
Changed
- AnalyticsContainer object is no longer created automatically on start-up; it is now spawned during UnityServices.InitializeAsync
[4.2.0] - 2022-08-15
Added
- SessionID property that returns the GUID value currently being used to populate the "sessionID" parameter of all events
Changed
- Reduced frequency of gameRunning event to reduce excess traffic (this will not affect the quality of your data)
Fixed
- SDK initialisation failing silently on WebGL due to problem with privacy consent flow
- SDK event batching for upload failing silently on WebGL
[4.1.0] - 2022-06-16
New
- Added a method to access the user ID used by Analytics at runtime
Fixed
- Events are now recorded with timestamps including milliseconds
- XML documentation is available for more model objects
- A better error message will be displayed when the project ID is missing
[4.0.1] - 2022-05-18
Fixed
- Change assertions to error logs for missing required parameters
[4.0.0] - 2022-05-12
The UGS Analytics is no longer pre-release! No other changes in this version.
[4.0.0-pre.3] - 2022-05-10
Fixed
- Events will now consistently use local time + offset for timestamps
- Fixes an issue that could occur when the SDK was disabled
[4.0.0-pre.2] - 2022-04-06
New
- Added a new event (transactionFailed) for recording failed transactions
Changed
- IDFA usage has also been removed from the SDK - this identifier will no longer be added to events automatically when available.
- This release restores the previous EventsAPI for backwards compatability with3.0.0versions of the SDK. This API will be removed in a future release.
[4.0.0-pre.1] - 2022-03-14
Breaking Changes
- The API of the Analytics package has been updated to match the other UGS packages. This means that APIs for recording events that were previously available on the Eventsstatic class are now available viaAnalyticsService.Instanceinstead. In addition, some classes that were previously nested in other types have been moved to standalone classes.- The Eventsstatic class has changed toAnalyticsService.Instance- the same event recording methods are found on this new instance
- The Transactionmethod now uses standalone classes forProduct,TransactionType, etc.
- The AdImpressionArgsobject has been changed to anAdImpressionParametersstruct
- Some parameter objects have been changed from lowercase fields to uppercase to match C# guidelines
 
- The 
- Code in the Unity.Services.Analytics.Editor.Settingsnamespace has been made internal as it was never meant to be public.
New Features
- Added support for sending a new event: acquisitionSource.
- Added a method to convert currency to units suitable for the Transaction event
- Added new Sample Scene
- Added abilitiy to disable and re-enable the Analytics SDK
Bug Fixes
- Fixed a bug that would block the main thread when trying to send large amounts of events
[3.0.0-pre.4] - 2022-02-15
- Fixed a bug where event data was not cached locally when the game closes
- Fixed a bug where floats were not serialized properly in cultures where the ,character is used for decimals rather than.
[3.0.0-pre.3] - 2022-01-27
- Adds support for using a custom analytics ID via the Core SDK.
[3.0.0-pre.2] - 2021-12-02
- Analytics Runtime dependency has been updated, the PIPL headers are now included in ForgetMeevent, when appropriate.
[3.0.0-pre.1] - 2021-11-26
Added
Breaking Change:
- New APIs provided for checking if PIPL consent is needed, and recording users' consent. It is now required to check if any consent is required, and provide that consent if necessary, before the events will be sent from the SDK.
[2.0.7-pre.7] - 2021-10-20
Added
- projectID parameter to all events
Fixed
- GameStart event idLocalProjecthaving a nonsense value
- Heartbeat cadence being affected by Time Scale
- Failing to compile for WebGL with error " The type or namespace name 'DllImportAttribute' could not be found"
Changed
- User opt-out of data collection. Developers must expose this mechanism to users in an appropriate way:
- Give users access to the privacy policy, the URL for which is stored in the Events.PrivacyUrlproperty
- Disable analytics if requested using the Events.OptOut()method
 
- Give users access to the privacy policy, the URL for which is stored in the 
Removed
- Deprecated Transaction event isInitiatorparameter
- Deprecated previous opt-out mechanism (DataPrivacy and DataPrivacyButton)
[2.0.7-pre.6] - 2021-08-26
Fixed
- GameRunning event being recorded and uploaded erratically
- Removed some obsolete steps from readme
- Clarified and added some missing XmlDoc comments on public methods
[2.0.7-pre.4] - 2021-08-19
Changed
- Updated README
- Regenerated .metafiles for privacy
[2.0.7-pre.2] - 2021-08-18
Removed
- Version of CustomData method that takes an Event Version
Changed
- Regen'd .metafiles for privacy
Added
- Added UI as a dependency
[2.0.7] - 2021-08-09
Changed
- New custom code entry point.
- Arguments for AdImpression now handled by an object.
Added
- New way to interact with buffer.
[2.0.6] - 2021-06-17
Changed
- Bump dependencies
[2.0.5] - 2021-05-18
Changed
- Use Core for Authentication ID
- Use Core for Install ID
- Use httpsinstead ofhttp
[2.0.4] - 2021-05-10
Changed
- URL now uses the new collect url based off project_id and not a legacy one.
Removed
- UI for setting up the collect url.
[2.0.3] - 2021-05-05
Added
- Re added support for 2019.4
- Update dependencies
[2.0.2] - 2021-04-29
Added
- Project settings UI
Removed
- Setup()API entry point
- Custom UserID and SessionID
[0.1.1] - 2021-04-01
Changed
- Removed util package
- Changed RecordEvententry point toCustomData
[0.1.0] - 2021-03-31
Added
- Standard events