/FMNetwork

The new official FMobile Developer Pack v5, made for Swift!

Primary LanguageSwiftGNU General Public License v3.0GPL-3.0

FMNetwork

FMobile Developer Pack v5. The power of FMobile's latest engine, FMNetwork, in a simple Swift Package.

Important information: FMobile 5 and FMNetwork lost a lot of its features due to changes in iOS 15.2. Starting with iOS 16.0, Apple has also deprecated the CTCarrier object from the Core Telephony API, and building FMobile 5 using iOS 16.4+ as a target (SDK) will make FMobile and FMNetwork entirely unusable as all the values returned by the APIs will be generic.

Installation

Add https://github.com/GroupeMINASTE/FMNetwork.swift.git to your Swift Package configuration (or using the Xcode menu: File > Swift Packages > Add Package Dependency)

Usage

// Import the package
import CoreTelephony
import FMNetwork

// Create a variable and intitialize FMNetwork with the SIM card type you want.
// You can use .current, .sim, or .esim.
// Keep in mind that if you use .current, the SIM card type that will be returned in the card.type property is very likely to change to .sim or .esim accordingly.
let current = FMNetwork(.current)
let sim = FMNetwork(.sim)
let esim = FMNetwork(.esim)

// Then access the properies you want.
// The FMNetwork class is composed of two properties : card and network, giving you data about the SIM card itself and its connected network. For example:
if current.card.mcc == current.network.mcc {
    print("The card is in its home country!")
}

// If you want to access the complementary data provided by the official FMobile API service, you need to initiate the fmobile property. It is equal to nil by default, and needs to be initialized manually using the loadFMobileService() function after the FMNetwork object got initialized. The function is working in async, and requires an active Internet connection to work properly. The status property recieved by a completionHandler is a Bool indicating whether the retrieve of the data was successful or not. You are fully responsible of the mobile data consumed by this function.
current.loadFMobileService { (status) in
    if status {
        print(current.fmobile?.mcc)
    }
}

// You can also access some device properties, like the airplane mode status.
if current.device.isOnAirplaneMode {
    print("The device is on airplane mode!")
}

// Or you can access data about the connected Wi-Fi network.
// The device property is not depending on any mobile network, which means you can call it from any FMNetwork object, including the SIM and eSIM.
if let network = current.device.currentWifiNetwork {
    print("The device is connected to the " + network.ssid + " network.")
} else {
    print("The device is not connected to Wi-Fi, or the app does not meet the requirements.")
}

// To access the full documentation, you can use the Quick Help feature in Xcode. Simply Command + click on any item of FMNetwork you wrote (for example the first mcc), and click on Show Quick Help to view the entire documentation for that part of the code.

Public structure of the FMNetwork class

FMNetwork: (contains every data about a SIM card and its connected network)

  • card: FMNetworkSIMData (contains every data about a SIM card)
    • active: Bool (returns true if the SIM card is inserted and in use)
    • name: String (returns the name of the SIM card carrier, "Carrier" by default)
    • mcc: String (returns the Mobile Country Code (MCC) of the SIM card carrier, "---" by default)
    • mnc: String (returns the Mobile Network Code (MNC) of the SIM card carrier, "--" by default)
    • land: String (returns the uppercased 2-digit ISO country code* of the SIM card carrier, "--" by default)
    • type: FMNetworkType (.sim, .esim or .current)
    • plmns: [PLMN] (returns the list of mcc and mnc of the declared roaming PLMNs, [] by default)
  • network: FMNetworkData (contains every data about the connected network of a SIM card)
    • name: String (returns the name of the connected network, "Carrier" by default)
    • mcc: String (returns the Mobile Country Code (MCC) of the connected network, "---" by default)
    • mnc: String (returns the Mobile Network Code (MNC) of the connected network, "--" by default)
    • land: String (returns the uppercased 2-digit ISO country code* of the connected network, "--" by default)
    • connected: String (Core Telephony CTRadioAccessTechnology constant, "" by default)
  • fmobile: FMobileService? (contains complementary OTA data about the SIM card carrier, optional)
    • mcc: String? (returns the declared Mobile Country Code (MCC) of the SIM card carrier, nil by default)
    • mnc: String? (returns the declared Mobile Network Code (MNC) of the SIM card carrier, nil by default)
    • stms: Double? (returns the declared max speed of the national roaming network, 5000/nil by default)
    • hp: String? (returns the declared widest protocol for the home network, CTRadioAccessTechnologyWCDMA/nil by default)
    • nrp: String? (returns the declared widest protocol for the national roaming network, CTRadioAccessTechnologyHSDPA/nil by default)
    • land: String? (returns the declared 2-digit ISO country code* of the SIM card carrier, nil by default)
    • itiname: String? (returns the declared national roaming network name, homename/nil by default)
    • homename: String? (returns the declared home network name, nil by default)
    • itimnc: String? (returns the declared Mobile Netowk Code (MNC) of thenational roaming network, "99"/nil by default)
    • nrfemto: Bool? (returns the declared Femtocell activation status on the same radio technology as nrp, false/nil by default)
    • out2G: Bool? (returns the declared lack of 2G network for the home network, false/nil by default)
    • setupDone: Bool? (returns the declared FMobile setup done property, true/nil by default)
    • minimalSetup: Bool? (returns the declared FMobile minimal setup property, true/nil by default)
    • disableFMobileCore: Bool? (returns the declared FMobile national roaming core disability status, true/nil by default)
    • countriesData: [String]? (returns the declared 2-digit ISO country codes included for data only at no charge, nil by default)
    • countriesVoice: [String]? (returns the declared 2-digit ISO country codes included for voice only at no charge, nil by default)
    • countriesVData: [String]? (returns the declared 2-digit ISO country codes included for voice and data only at no charge, nil by default)
    • carrierServices: [[String]]? (returns the declared Carrier Services available to be displayed and used inside apps, nil by default)
    • roamLTE: Bool? (returns the declared 4G LTE national roaming status, nil by default)
    • roam5G: Bool? (returns the declared 5G national roaming status, nil by default)
    • chasedmnc: String? (returns the MNC used to detect the national roaming network - if mnc, requires a speedtest to detect the national roaming, mnc/nil by default)
    • nrdec: Bool? (returns the national roaming declaration status - if true, chasedmnc = mnc, false/nil by default)
  • device: FMNetworkDevice (contains all the data about the device, independently from the mobile network)
    • currentWifiNetwork: WIFI? (returns all the data about the currently connected Wi-Fi network, if the prerequisites are satisfied, nil by default)
    • isOnPhoneCall: Bool (retruns the call status, for phone calls as well as VoIP apps using CallKit, false by default)
    • isConnectedToNetwork: Bool (returns the Internet connection status, no matter how)
    • isOnAirplaneMode: Bool (returns the Airplane Mode toggle status for the device)

*There is an exception for International carriers. They might return the non-standardised 2-digits code "WD", standing for World.

To access the full documentation, you can use the Quick Help feature in Xcode. Simply Command + click on any property of the FMNetwork item you wrote, and click on Show Quick Help to view the entire documentation for that code.

Licence

Copyright (C) 2021 Groupe MINASTE

This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version.

This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.

You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.

Examples

  • FMNetworkExample, the official example repository for the FMNetwork Swift Package.

Donations

If you are feeling generous and want to give a little something to the developer, you can do that here. It's completely optionnal.

You can also donate to the non-profit organisation directly, to help us finance our bigger projects here.