Skip to content

Commit

Permalink
Refactored Swift samples to use async/await
Browse files Browse the repository at this point in the history
PiperOrigin-RevId: 688207696
  • Loading branch information
Justin Malandruccolo authored and copybara-github committed Oct 21, 2024
1 parent 69fb7c6 commit 250008d
Show file tree
Hide file tree
Showing 10 changed files with 198 additions and 180 deletions.
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
//
// Copyright 2023 Google LLC
// Copyright (C) 2023 Google LLC
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
Expand Down Expand Up @@ -37,12 +37,12 @@ class GoogleMobileAdsConsentManager: NSObject {
/// Helper method to call the UMP SDK methods to request consent information and load/present a
/// consent form if necessary.
func gatherConsent(
from consentFormPresentationviewController: UIViewController,
from viewController: UIViewController? = nil,
consentGatheringComplete: @escaping (Error?) -> Void
) {
let parameters = UMPRequestParameters()

//For testing purposes, you can force a UMPDebugGeography of EEA or not EEA.
// For testing purposes, you can use UMPDebugGeography to simulate a location.
let debugSettings = UMPDebugSettings()
// debugSettings.geography = UMPDebugGeography.EEA
parameters.debugSettings = debugSettings
Expand All @@ -54,20 +54,22 @@ class GoogleMobileAdsConsentManager: NSObject {
return consentGatheringComplete(requestConsentError)
}

UMPConsentForm.loadAndPresentIfRequired(from: consentFormPresentationviewController) {
loadAndPresentError in

// Consent has been gathered.
consentGatheringComplete(loadAndPresentError)
Task { @MainActor in
do {
try await UMPConsentForm.loadAndPresentIfRequired(from: viewController)
// Consent has been gathered.
consentGatheringComplete(nil)
} catch {
consentGatheringComplete(error)
}
}
}
}

/// Helper method to call the UMP SDK method to present the privacy options form.
func presentPrivacyOptionsForm(
from viewController: UIViewController, completionHandler: @escaping (Error?) -> Void
) {
UMPConsentForm.presentPrivacyOptionsForm(
from: viewController, completionHandler: completionHandler)
@MainActor func presentPrivacyOptionsForm(from viewController: UIViewController? = nil)
async throws
{
try await UMPConsentForm.presentPrivacyOptionsForm(from: viewController)
}
}
42 changes: 23 additions & 19 deletions Swift/admob/AppOpenExample/AppOpenExample/MainViewController.swift
Original file line number Diff line number Diff line change
Expand Up @@ -30,30 +30,34 @@ class MainViewController: UIViewController {
}

@IBAction func privacySettingsTapped(_ sender: UIBarButtonItem) {
GoogleMobileAdsConsentManager.shared.presentPrivacyOptionsForm(from: self) {
[weak self] (formError) in
guard let self, let formError else { return }

let alertController = UIAlertController(
title: formError.localizedDescription, message: "Please try again later.",
preferredStyle: .alert)
alertController.addAction(UIAlertAction(title: "OK", style: .cancel))
self.present(alertController, animated: true)
Task {
do {
try await GoogleMobileAdsConsentManager.shared.presentPrivacyOptionsForm(from: self)
} catch {
let alertController = UIAlertController(
title: error.localizedDescription, message: "Please try again later.",
preferredStyle: .alert)
alertController.addAction(
UIAlertAction(
title: "OK", style: .cancel,
handler: nil))
present(alertController, animated: true)
}
}
}

/// Handle ad inspector launch.
@IBAction func adInspectorTapped(_ sender: UIBarButtonItem) {
GADMobileAds.sharedInstance().presentAdInspector(from: self) {
// Error will be non-nil if there was an issue and the inspector was not displayed.
[weak self] error in
guard let self, let error else { return }

let alertController = UIAlertController(
title: error.localizedDescription, message: "Please try again later.",
preferredStyle: .alert)
alertController.addAction(UIAlertAction(title: "OK", style: .cancel))
self.present(alertController, animated: true)
Task {
do {
try await GADMobileAds.sharedInstance().presentAdInspector(from: self)
} catch {
let alertController = UIAlertController(
title: error.localizedDescription, message: "Please try again later.",
preferredStyle: .alert)
alertController.addAction(UIAlertAction(title: "OK", style: .cancel))
present(alertController, animated: true)
}
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -37,12 +37,12 @@ class GoogleMobileAdsConsentManager: NSObject {
/// Helper method to call the UMP SDK methods to request consent information and load/present a
/// consent form if necessary.
func gatherConsent(
from consentFormPresentationviewController: UIViewController,
from viewController: UIViewController? = nil,
consentGatheringComplete: @escaping (Error?) -> Void
) {
let parameters = UMPRequestParameters()

//For testing purposes, you can force a UMPDebugGeography of EEA or not EEA.
// For testing purposes, you can use UMPDebugGeography to simulate a location.
let debugSettings = UMPDebugSettings()
// debugSettings.geography = UMPDebugGeography.EEA
parameters.debugSettings = debugSettings
Expand All @@ -54,20 +54,22 @@ class GoogleMobileAdsConsentManager: NSObject {
return consentGatheringComplete(requestConsentError)
}

UMPConsentForm.loadAndPresentIfRequired(from: consentFormPresentationviewController) {
loadAndPresentError in

// Consent has been gathered.
consentGatheringComplete(loadAndPresentError)
Task { @MainActor in
do {
try await UMPConsentForm.loadAndPresentIfRequired(from: viewController)
// Consent has been gathered.
consentGatheringComplete(nil)
} catch {
consentGatheringComplete(error)
}
}
}
}

/// Helper method to call the UMP SDK method to present the privacy options form.
func presentPrivacyOptionsForm(
from viewController: UIViewController, completionHandler: @escaping (Error?) -> Void
) {
UMPConsentForm.presentPrivacyOptionsForm(
from: viewController, completionHandler: completionHandler)
@MainActor func presentPrivacyOptionsForm(from viewController: UIViewController? = nil)
async throws
{
try await UMPConsentForm.presentPrivacyOptionsForm(from: viewController)
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -71,37 +71,37 @@ class ViewController: UIViewController, GADFullScreenContentDelegate {
/// Handle changes to user consent.
@IBAction func privacySettingsTapped(_ sender: UIBarButtonItem) {
pauseGame()

GoogleMobileAdsConsentManager.shared.presentPrivacyOptionsForm(from: self) {
[weak self] formError in
guard let self else { return }
guard let formError else { return self.resumeGame() }

let alertController = UIAlertController(
title: formError.localizedDescription, message: "Please try again later.",
preferredStyle: .alert)
alertController.addAction(
UIAlertAction(
title: "OK", style: .cancel,
handler: { _ in
self.resumeGame()
}))
self.present(alertController, animated: true)
Task {
do {
try await GoogleMobileAdsConsentManager.shared.presentPrivacyOptionsForm(from: self)
resumeGame()
} catch {
let alertController = UIAlertController(
title: error.localizedDescription, message: "Please try again later.",
preferredStyle: .alert)
alertController.addAction(
UIAlertAction(
title: "OK", style: .cancel,
handler: { _ in
self.resumeGame()
}))
present(alertController, animated: true)
}
}
}

/// Handle ad inspector launch.
@IBAction func adInspectorTapped(_ sender: UIBarButtonItem) {
GADMobileAds.sharedInstance().presentAdInspector(from: self) {
// Error will be non-nil if there was an issue and the inspector was not displayed.
[weak self] error in
guard let self, let error else { return }

let alertController = UIAlertController(
title: error.localizedDescription, message: "Please try again later.",
preferredStyle: .alert)
alertController.addAction(UIAlertAction(title: "OK", style: .cancel))
self.present(alertController, animated: true)
Task {
do {
try await GADMobileAds.sharedInstance().presentAdInspector(from: self)
} catch {
let alertController = UIAlertController(
title: error.localizedDescription, message: "Please try again later.",
preferredStyle: .alert)
alertController.addAction(UIAlertAction(title: "OK", style: .cancel))
present(alertController, animated: true)
}
}
}

Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
//
// Copyright 2023 Google LLC
// Copyright (C) 2023 Google LLC
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
Expand Down Expand Up @@ -37,12 +37,12 @@ class GoogleMobileAdsConsentManager: NSObject {
/// Helper method to call the UMP SDK methods to request consent information and load/present a
/// consent form if necessary.
func gatherConsent(
from consentFormPresentationviewController: UIViewController,
from viewController: UIViewController? = nil,
consentGatheringComplete: @escaping (Error?) -> Void
) {
let parameters = UMPRequestParameters()

//For testing purposes, you can force a UMPDebugGeography of EEA or not EEA.
// For testing purposes, you can use UMPDebugGeography to simulate a location.
let debugSettings = UMPDebugSettings()
// debugSettings.geography = UMPDebugGeography.EEA
parameters.debugSettings = debugSettings
Expand All @@ -54,20 +54,22 @@ class GoogleMobileAdsConsentManager: NSObject {
return consentGatheringComplete(requestConsentError)
}

UMPConsentForm.loadAndPresentIfRequired(from: consentFormPresentationviewController) {
loadAndPresentError in

// Consent has been gathered.
consentGatheringComplete(loadAndPresentError)
Task { @MainActor in
do {
try await UMPConsentForm.loadAndPresentIfRequired(from: viewController)
// Consent has been gathered.
consentGatheringComplete(nil)
} catch {
consentGatheringComplete(error)
}
}
}
}

/// Helper method to call the UMP SDK method to present the privacy options form.
func presentPrivacyOptionsForm(
from viewController: UIViewController, completionHandler: @escaping (Error?) -> Void
) {
UMPConsentForm.presentPrivacyOptionsForm(
from: viewController, completionHandler: completionHandler)
@MainActor func presentPrivacyOptionsForm(from viewController: UIViewController? = nil)
async throws
{
try await UMPConsentForm.presentPrivacyOptionsForm(from: viewController)
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -130,30 +130,34 @@ class ViewController: UIViewController {

/// Handle changes to user consent.
@IBAction func privacySettingsTapped(_ sender: UIBarButtonItem) {
GoogleMobileAdsConsentManager.shared.presentPrivacyOptionsForm(from: self) {
[weak self] formError in
guard let self, let formError else { return }

let alertController = UIAlertController(
title: formError.localizedDescription, message: "Please try again later.",
preferredStyle: .alert)
alertController.addAction(UIAlertAction(title: "OK", style: .cancel))
self.present(alertController, animated: true)
Task {
do {
try await GoogleMobileAdsConsentManager.shared.presentPrivacyOptionsForm(from: self)
} catch {
let alertController = UIAlertController(
title: error.localizedDescription, message: "Please try again later.",
preferredStyle: .alert)
alertController.addAction(
UIAlertAction(
title: "OK", style: .cancel,
handler: nil))
present(alertController, animated: true)
}
}
}

/// Handle ad inspector launch.
@IBAction func adInspectorTapped(_ sender: UIBarButtonItem) {
GADMobileAds.sharedInstance().presentAdInspector(from: self) {
// Error will be non-nil if there was an issue and the inspector was not displayed.
[weak self] error in
guard let self, let error else { return }

let alertController = UIAlertController(
title: error.localizedDescription, message: "Please try again later.",
preferredStyle: .alert)
alertController.addAction(UIAlertAction(title: "OK", style: .cancel))
self.present(alertController, animated: true)
Task {
do {
try await GADMobileAds.sharedInstance().presentAdInspector(from: self)
} catch {
let alertController = UIAlertController(
title: error.localizedDescription, message: "Please try again later.",
preferredStyle: .alert)
alertController.addAction(UIAlertAction(title: "OK", style: .cancel))
present(alertController, animated: true)
}
}
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -240,37 +240,37 @@ class GameViewController: UIViewController, GADFullScreenContentDelegate {
/// Handle changes to user consent.
@IBAction func privacySettingsTapped(_ sender: UIBarButtonItem) {
pauseGame()

GoogleMobileAdsConsentManager.shared.presentPrivacyOptionsForm(from: self) {
[weak self] formError in
guard let self else { return }
guard let formError else { return self.resumeGame() }

let alertController = UIAlertController(
title: formError.localizedDescription, message: "Please try again later.",
preferredStyle: .alert)
alertController.addAction(
UIAlertAction(
title: "OK", style: .cancel,
handler: { _ in
self.resumeGame()
}))
self.present(alertController, animated: true)
Task {
do {
try await GoogleMobileAdsConsentManager.shared.presentPrivacyOptionsForm(from: self)
resumeGame()
} catch {
let alertController = UIAlertController(
title: error.localizedDescription, message: "Please try again later.",
preferredStyle: .alert)
alertController.addAction(
UIAlertAction(
title: "OK", style: .cancel,
handler: { _ in
self.resumeGame()
}))
present(alertController, animated: true)
}
}
}

/// Handle ad inspector launch.
@IBAction func adInspectorTapped(_ sender: UIBarButtonItem) {
GADMobileAds.sharedInstance().presentAdInspector(from: self) {
// Error will be non-nil if there was an issue and the inspector was not displayed.
[weak self] error in
guard let self, let error else { return }

let alertController = UIAlertController(
title: error.localizedDescription, message: "Please try again later.",
preferredStyle: .alert)
alertController.addAction(UIAlertAction(title: "OK", style: .cancel))
self.present(alertController, animated: true)
Task {
do {
try await GADMobileAds.sharedInstance().presentAdInspector(from: self)
} catch {
let alertController = UIAlertController(
title: error.localizedDescription, message: "Please try again later.",
preferredStyle: .alert)
alertController.addAction(UIAlertAction(title: "OK", style: .cancel))
present(alertController, animated: true)
}
}
}

Expand Down
Loading

0 comments on commit 250008d

Please sign in to comment.