Apple App Store: Difference between revisions
| mNo edit summary |  added summary for less technical users | ||
| (13 intermediate revisions by 7 users not shown) | |||
| Line 1: | Line 1: | ||
| {{ToneWarning}} | |||
| [[File:App Store (iOS).svg|thumb|150px]] | [[File:App Store (iOS).svg|thumb|150px]] | ||
| [[Apple]] uses  | '''[[Apple]]''' uses a range of technical measures to protect their App Store ecosystem and reduce consumer choice. These measures obscure the company's business intentions, creating roadblocks for app developers and users, while typically citing security reasons for their existence. This actively hurts the ability for lawmakers to advocate for the rights of consumers and businesses in Apple's ecosystem, and prevents apps from being as useful as their customers expect. | ||
| A never-ending demand for a cut of every sale of a digital product, ranging from game currency, to supporting content creators,<ref name="patreon">https://www.theverge.com/2024/8/12/24218629/patreon-membership-ios-30-percent-apple-tax</ref> to booking a Zoom call with a local business,<ref name="facebook">https://www.reuters.com/article/us-facebook-apple-exclusive/exclusive-facebook-says-apple-rejected-its-attempt-to-tell-users-about-app-store-fees-idUSKBN25O042/</ref> hurts the ability for app developers to innovate. These developers, working hard and pulling countless hours to build a quality app, always need to take Apple's (and [[Google]]'s) demands into account - specifically, between 15% and 30% of  | A never-ending demand for a cut of every sale of a digital product, ranging from game currency, to supporting content creators,<ref name="patreon">{{Cite web |last=Roth |first=Emma |date=12 Aug 2024 |title=Patreon: adding Apple’s 30 percent tax is the price of staying in the App Store |url=https://www.theverge.com/2024/8/12/24218629/patreon-membership-ios-30-percent-apple-tax |url-status=live |access-date=16 Mar 2025 |website=[[The Verge]]}}</ref> to booking a Zoom call with a local business,<ref name="facebook">{{Cite web |last=Paul |first=Katie |last2=Nellis |first2=Stephen |date=28 Aug 2020 |title=Exclusive: Facebook says Apple rejected its attempt to tell users about App Store fees |url=https://www.reuters.com/article/us-facebook-apple-exclusive/exclusive-facebook-says-apple-rejected-its-attempt-to-tell-users-about-app-store-fees-idUSKBN25O042/ |url-status=live |access-date=16 Mar 2025 |website=[[Reuters]]}}</ref> hurts the ability for app developers to innovate. These developers, working hard and pulling countless hours to build a quality app, always need to take Apple's (and [[Google]]'s) demands into account - specifically, a fee of between 15% and 30% of all revenue collected via the app. This is revenue that can be reinvested into the app, but instead must be earmarked for the platforms they are '''required''' to use to reach their customers. | ||
| Because this is a clear problem, several governments, including South Korea,<ref>https://www.reuters.com/technology/skorea-approves-rules-app-store-law-targeting-apple-google-2022-03-08/</ref> Japan,<ref>https://www.theregister.com/2024/06/13/japan_smartphone_software_law/</ref> the European Union,<ref>[[wikipedia:Digital Markets Act|Digital Markets Act]]</ref> the United Kingdom,<ref>https://www.gov.uk/cma-cases/investigation-into-apple-appstore</ref> Australia,<ref>https://www.accc.gov.au/media-release/dominance-of-apple-and-googles-app-stores-impacting-competition-and-consumers</ref> as well as the US and a handful of states,<ref>[[wikipedia:Open App Markets Act|Open App Markets Act]]</ref><ref>https://www.congress.gov/bill/118th-congress/senate-bill/5364/text/is</ref><ref name="doj">https://apnews.com/article/apple-antitrust-monopoly-app-store-justice-department-822d7e8f5cf53a2636795fcc33ee1fc3</ref><ref>https://azcapitoltimes.com/news/2021/02/19/its-time-to-free-ourselves-from-big-tech-monopoly/</ref> have opened investigations into anti-competitive practices, or considered or already passed legislation to force "gatekeeper platforms" such as Apple to be more reasonable with third-party developers. | Because this is a clear problem, several governments, including South Korea,<ref>{{Cite web |date=8 Mar 2022 |title=South Korea approves rules on app store law targeting Apple, Google |url=https://www.reuters.com/technology/skorea-approves-rules-app-store-law-targeting-apple-google-2022-03-08/ |url-status=live |access-date=16 Mar 2025 |website=[[Reuters]]}}</ref> Japan,<ref>{{Cite web |last=Sharwood |first=Simon |date=13 Jun 2024 |title=Japan forces Apple and Google to allow third-party app stores and payments |url=https://www.theregister.com/2024/06/13/japan_smartphone_software_law/ |url-status=live |access-date=16 Mar 2025 |website=[[The Register]]}}</ref> the European Union,<ref>[[wikipedia:Digital Markets Act|Digital Markets Act]]</ref> the United Kingdom,<ref>{{Cite web |last=Competition and Markets Authority |date=4 Mar 2021 |title=Investigation into Apple AppStore |url=https://www.gov.uk/cma-cases/investigation-into-apple-appstore |url-status=live |access-date=16 Mar 2025 |website=[[gov.uk]]}}</ref> Australia,<ref>{{Cite web |date=28 Apr 2021 |title=Dominance of Apple and Google's app stores impacting competition and consumers |url=https://www.accc.gov.au/media-release/dominance-of-apple-and-googles-app-stores-impacting-competition-and-consumers |url-status=live |access-date=16 Mar 2025 |website=[[ACCC]]}}</ref> as well as the US and a handful of states,<ref>[[wikipedia:Open App Markets Act|Open App Markets Act]]</ref><ref>{{Cite web |date=20 Nov 2024 |title=S.5364 - App Store Accountability Act |url=https://www.congress.gov/bill/118th-congress/senate-bill/5364/text/is |url-status=live |access-date=16 Mar 2025 |website=[[congress.gov]]}}</ref><ref name="doj">{{Cite web |last=Balsamo |first=Mike |last2=Liedtke |first2=Mike |last3=Whitehurst |first3=Lindsay |last4=Bajak |first4=Frank |date=21 Mar 2024 |title=Justice Department sues Apple, alleging it illegally monopolized the smartphone market |url=https://apnews.com/article/apple-antitrust-monopoly-app-store-justice-department-822d7e8f5cf53a2636795fcc33ee1fc3 |url-status=live |access-date=16 Mar 2025 |website=[[APNews]]}}</ref><ref>{{Cite web |date=19 Feb 2021 |title=It’s time to free ourselves from ‘Big Tech’ monopoly |url=https://azcapitoltimes.com/news/2021/02/19/its-time-to-free-ourselves-from-big-tech-monopoly/ |url-status=live |access-date=16 Mar 2025 |website=[[Arizona Capitol Times]]}}</ref> have opened investigations into anti-competitive practices, or considered or already passed legislation to force "gatekeeper platforms" such as Apple to be more reasonable with third-party developers. | ||
| This being a major threat to Apple's revenue stream (interestingly, one they claim to be unsure is profitable<ref>https://9to5mac.com/2024/04/17/app-store-is-profitable-apple-notes/</ref><ref>https://9to5mac.com/2025/01/17/apple-denies-app-store-profit-margin-is-75-claims-to-have-no-clue/</ref>), they have responded with practices such as geoblocking certain operating system functionality based on physical location,<ref>https://theapplewiki.com/wiki/Eligibility</ref> misrepresenting/overstating risks, and using  | This being a major threat to Apple's revenue stream (interestingly, one they claim to be unsure is profitable<ref>{{Cite web |last=Lovejoy |first=Ben |date=17 Apr 2024 |title=Schiller doesn’t know whether the App Store is profitable; there are no minutes of meetings |url=https://9to5mac.com/2024/04/17/app-store-is-profitable-apple-notes/ |url-status=live |access-date=16 Mar 2025 |website=[[9to5Mac]]}}</ref><ref>{{Cite web |last=Lovejoy |first=Ben |date=17 Jan 2025 |title=Apple denies App Store profit margin is 75% – claims to have no clue |url=https://9to5mac.com/2025/01/17/apple-denies-app-store-profit-margin-is-75-claims-to-have-no-clue/ |url-status=live |access-date=16 Mar 2025 |website=[[9t05Mac]]}}</ref>), they have responded with practices such as geoblocking certain operating system functionality based on physical location,<ref>{{Cite web |title=Eligibility |url=https://theapplewiki.com/wiki/Eligibility |url-status=live |access-date=16 Mar 2025 |website=[[The Apple Wiki]]}}</ref> misrepresenting/overstating risks, and using careful wording with commonly-understood terms to describe unreasonably difficult-to-use systems. | ||
| ==Background info== | ==Background info== | ||
| Line 17: | Line 18: | ||
| ==In-app purchases== | ==In-app purchases== | ||
| Apple has been collecting users' credit card numbers since  | Apple has been collecting users' credit card numbers since launching the iTunes Store in 2004. The launch of the App Store in 2008, followed by the introduction of in-app purchases (IAPs) in 2009, gave iPhone app developers the opportunity to sell app features to users. The IAP system is provided as a developer framework named [https://developer.apple.com/storekit/ StoreKit]. Apps and their in-app purchases are managed through a dashboard named [https://developer.apple.com/app-store-connect/ App Store Connect]. App sales have eclipsed iTunes Store sales, and are now a primary focus of Apple's Media Services division. | ||
| Apple requires  | Apple requires any purchase of a digital good or service in an app to use their in-app purchase system. This may seem reasonable because the customer may inevitably call Apple support, demanding a refund for an app they have issues with. Apple would rather give that refund and leave the customer with a positive support experience, than to provide a messy process involving contacting a third-party, whose customer service is likely nowhere near the same experience. | ||
| App Store purchase fees are between 15% and 30%. In September 2016, Apple expanded subscriptions to be available to any type of app, also introducing a 15% discount incentive when the user has already subscribed for a year.<ref>https://www.theverge.com/2016/9/2/12774758/apple-developers-app-store-new-subscription-rules</ref> In November 2020, Apple introduced a reduced 15% fee for app developers with revenue below $1 million per year | App Store purchase fees are between 15% and 30%. In September 2016, Apple expanded subscriptions to be available to any type of app, also introducing a 15% discount incentive when the user has already subscribed for a year.<ref>{{Cite web |last=Goode |first=Lauren |date=2 Sep 2016 |title=Apple’s new subscription offerings are now available to App Store developers |url=https://www.theverge.com/2016/9/2/12774758/apple-developers-app-store-new-subscription-rules |url-status=live |access-date=16 Mar 2025 |website=[[The Verge]]}}</ref> In November 2020, Apple introduced a reduced 15% fee for app developers with revenue below $1 million per year.<ref>{{Cite web |last=Centers |first=Josh |date=18 Nov 2020 |title=Apple Drops App Store Commission to 15% for Small Developers |url=https://tidbits.com/2020/11/18/apple-drops-app-store-commission-to-15-for-small-developers/ |access-date=16 Mar 2025 |website=[[TidBITS]]}}</ref> For developers above this threshold, and for cases excluded from this program such as for games, the fee is 30%. In the 2008 announcement of the App Store, Apple considered this a reasonable, industry-standard fee. However, the way we use apps has significantly evolved since 2009 - the world has shifted to heavily depend upon on mobile apps, which have also evolved into more complex and sustainable business models than a simple one-time purchase. | ||
| [[wikipedia:Stripe, Inc.|Stripe]], a  | [[wikipedia:Stripe, Inc.|Stripe]], a popular platform used for payments on the web, uses a base fee of 2.9% plus a fixed $0.30 in the United States.<ref>{{Cite web |title=Pricing |url=https://stripe.com/it/pricing |url-status=live |access-date=16 Mar 2025 |website=[[Stripe]]}}</ref> With add-on services, before considering volume discounts, a Stripe transaction may rather have a cost of 6.4% + $1.10.<ref>Calculated from base fee (2.9% + $0.30) + international card (1.5%) + adaptive pricing (2%) + international payment methods ($0.80), as of January 2025</ref> Stripe has been used by businesses ranging from small online stores, to [[OpenAI]] for ChatGPT Plus. Competing payments services have similar or identical fees to Stripe. '''The in-app purchase system does not provide sufficient value to justify considerably higher fees than alternative payment platforms.''' | ||
| The App Store system poorly handles secondary marketplaces of digital services that exist within the primary App Store marketplace, such as Patreon. Apple, however, still requires companies in the business of selling digital services to use this inadequate system. This requires the app to account for Apple's fee, which is significant enough to often warrant increasing prices, and to follow rules even if they do not make sense for the nature of service they are providing. Apple has frequently been found in disputes with such apps. This injects extra complication at no benefit to the marketplace, the creator, or the customer - only to Apple, who has little to no involvement after delivering the initial app download to the user's phone. The significant fee also often drives app developers to consider building their app around an advertising model instead, creating privacy concerns. | The App Store system poorly handles secondary marketplaces of digital services that exist within the primary App Store marketplace, such as Patreon. Apple, however, still requires companies in the business of selling digital services to use this inadequate system. This requires the app to account for Apple's fee, which is significant enough to often warrant increasing prices, and to follow rules even if they do not make sense for the nature of service they are providing. Apple has frequently been found in disputes with such apps. This injects extra complication at no benefit to the marketplace, the creator, or the customer - only to Apple, who has little to no involvement after delivering the initial app download to the user's phone. The significant fee also often drives app developers to consider building their app around an advertising model instead, creating privacy concerns. | ||
| Line 29: | Line 30: | ||
| Additionally, the 15% small businesses fee discount is judged based on the app's overall turnover, and is not based on individual creators in the app's marketplace. An app that turns over $1 million per year by providing services to creators that individually make less than $1 million per year does not have the opportunity to use the discount. | Additionally, the 15% small businesses fee discount is judged based on the app's overall turnover, and is not based on individual creators in the app's marketplace. An app that turns over $1 million per year by providing services to creators that individually make less than $1 million per year does not have the opportunity to use the discount. | ||
| Apple, often together with Google, use lobbying efforts in the United States and other countries in an attempt to minimize the issues. "ACT | The App Association", pitched as an association of independent small business app developers, is at least 50% funded by Apple, and does not list its claimed 2,000 members.<ref>http://www.fosspatents.com/2021/10/not-class-act-so-called-app-association.html</ref><ref>http://www.fosspatents.com/2022/09/vast-majority-of-act-app-associations.html</ref> In March 2024, the United States Department of Justice along with 16 state attorneys-general filed a lawsuit against Apple, including an accusation that the company "extracts more money from consumers, developers, content creators, artists, publishers, small businesses, and merchants, among others".<ref name="doj" /> The future of this lawsuit is unclear as of  | Apple, often together with Google, use lobbying efforts in the United States and other countries in an attempt to minimize the issues. "ACT | The App Association", pitched as an association of independent small business app developers, is at least 50% funded by Apple, and does not list its claimed 2,000 members.<ref>{{Cite web |date=1 Oct 2021 |title=Not a class ACT: the so-called App Association is simply an Apple Association and does NOT represent app developers' interests in fair distribution terms |url=http://www.fosspatents.com/2021/10/not-class-act-so-called-app-association.html |url-status=live |access-date=16 Mar 2025 |website=[[FOSS Patents]]}}</ref><ref>{{Cite web |date=19 Sep 2022 |title=Vast majority of ACT {{!}} The App Association's funding comes from Apple, former employees tell Bloomberg: astroturfing against app developers' interests |url=http://www.fosspatents.com/2022/09/vast-majority-of-act-app-associations.html |url-status=live |access-date=16 Mar 2025 |website=[[FOSS Patents]]}}</ref> In March 2024, the United States Department of Justice along with 16 state attorneys-general filed a lawsuit against Apple, including an accusation that the company "extracts more money from consumers, developers, content creators, artists, publishers, small businesses, and merchants, among others".<ref name="doj" /> The future of this lawsuit is unclear as of April 2025. | ||
| Despite criticism of Apple forcing their fee into transactions with small businesses and creators on [[#Patreon|Patreon]], [[#Facebook online events|Facebook]], and similar platforms, on 23 January 2025, Apple announced the Advanced Commerce API. It "support[s] developers' evolving business models - such as exceptionally large content catalogs, creator experiences, and subscriptions with optional add-ons".<ref>https://developer.apple.com/news/?id=yxy958ya</ref> While positioned as a way for such businesses to save development time and avoid ongoing costs by building on top of Apple's mature payments platform, its use is in fact necessary for these businesses to work within the App Store guidelines, as seen in cases outlined below. The feature requires submitting the app's business model to Apple for approval. This continues a trend of requiring Apple's consent to conduct business in a place users have been trained to expect it. | Despite criticism of Apple forcing their fee into transactions with small businesses and creators on [[#Patreon|Patreon]], [[#Facebook online events|Facebook]], and similar platforms, on 23 January 2025, Apple announced the Advanced Commerce API. It "support[s] developers' evolving business models - such as exceptionally large content catalogs, creator experiences, and subscriptions with optional add-ons".<ref>{{Cite web |date=23 Jan 2025 |title=Introducing the Advanced Commerce API |url=https://developer.apple.com/news/?id=yxy958ya |url-status=live |access-date=16 Mar 2025 |website=[[Apple Developer]]}}</ref> While positioned as a way for such businesses to save development time and avoid ongoing costs by building on top of Apple's mature payments platform, its use is in fact necessary for these businesses to work within the App Store guidelines, as seen in cases outlined below. The feature requires submitting a description of the app's business model to Apple for approval. This continues a trend of requiring Apple's consent to conduct business in a place users have been trained to expect it. | ||
| Given Apple's strong incentives, and a ticking clock as legal pressure builds, it is not hard to find stories from app developers regarding poor experiences with Apple's app review process. | Given Apple's strong incentives, and a ticking clock as legal pressure builds, it is not hard to find stories from app developers regarding poor experiences with Apple's app review process. | ||
| :''This list is extremely incomplete. Please add examples if you know of any.'' | :''This list is extremely incomplete. Please add examples if you know of any.'' | ||
| ===Epic Games=== | |||
| {{hatnote|See also: [[wikipedia:Epic Games v. Apple|Epic Games v. Apple]] and [[wikipedia:Epic Games v. Google|Epic Games v. Google]]}} | |||
| [[Epic Games, Inc.]] is a video game developer and publisher, known for games such as [[Fortnite]] and [[Unreal Tournament]], the [[Unreal Engine]], and the [[Epic Games Store]]. | |||
| In 2018, Epic Games launched Fortnite on the iOS and Android platforms. The company made the unusual decision to not release the app on the [[Google Play Store]] - rather, it was made available as a standalone [[wikipedia:apk (file format)|Android app package]] file (.apk), which must be installed by following a series of manual steps.<ref>{{Cite web |last=Statt |first=Nick |date=3 Aug 2018 |title=Fortnite for Android will ditch Google Play Store for Epic’s website |url=https://www.theverge.com/2018/8/3/17645982/epic-games-fortnite-android-version-bypass-google-play-store |url-status=live |access-date=1 May 2025 |website=[[The Verge]]}}</ref> The app was also released on the [[Samsung]] [[Samsung Galaxy Store|Galaxy Store]]. Google offered a $147 million deal for Epic Games to release Fortnite on the Play Store, which the company declined.<ref>{{Cite web |last=Robertson |first=Adi |date=9 Nov 2023 |title=Google offered Epic $147 million to launch Fortnite on the Play Store |url=https://www.theverge.com/2023/11/8/23953262/google-epic-fortnite-play-store-investment-antitrust-trial |url-status=live |access-date=1 May 2025 |website=[[The Verge]]}}</ref> | |||
| On 22 April 2020, Fortnite was finally released on the Play Store.<ref>{{Cite web |last=Carpenter |first=Nicole |date=22 April 2020 |title=Fortnite available on the Google Play Store for the first time |url=https://www.polygon.com/2020/4/21/21229930/fortnite-available-on-google-play-android-mobile-devices |url-status=live |access-date=1 May 2025 |website=[[Polygon]]}}</ref> In a statement, the company explained: | |||
| <blockquote> | |||
| After 18 months of operating Fortnite on Android outside of the Google Play Store, we've come to a basic realization: Google puts software downloadable outside of Google Play at a disadvantage, through technical and business measures such as scary, repetitive security pop-ups for downloaded and updated software, restrictive manufacturer and carrier agreements and dealings, Google public relations characterizing third party software sources as malware, and new efforts such as Google Play Protect to outright block software obtained outside the Google Play store. | |||
| </blockquote> | |||
| On 13 August 2020, Epic Games launched a campaign against both Apple and Google's app store business practices. The company released app updates on both platforms, introducing a method for purchasing V-Bucks in-game currency at a 20% discount by directly transacting with Epic Games, against the developer rules of both platforms. The platforms responded by removing the game from their storefronts. Epic Games then filed civil antitrust lawsuits against both companies in the Northern District of California.<ref>{{Cite web |last=Statt |first=Nick |date=14 Aug 2020 |title=Epic Games is suing Apple |url=https://www.theverge.com/2020/8/13/21367963/epic-fortnite-legal-complaint-apple-ios-app-store-removal-injunctive-relief |url-status=live |access-date=1 May 2025 |website=[[The Verge]]}}</ref> The campaign, branded "Free Fortnite", was later extended with lawsuits and complaints in Australia,<ref>{{Cite web |date=18 Nov 2020 |title=Epic Games extends its fight against Apple to Australia |url=https://www.epicgames.com/site/en-US/freefortnite-australia-press-release |url-status=live |access-date=16 Mar 2025 |website=[[Epic Games]]}}</ref>, the European Union,<ref>{{Cite web |date=17 Feb 2021 |title=Epic Game Files EU Antitrust Complaint Against Apple |url=https://www.epicgames.com/site/en-US/news/epic-games-files-eu-antitrust-complaint-against-apple |url-status=live |access-date=16 Mar 2025 |website=[[Epic Games]]}}</ref> and the United Kingdom.<ref>{{Cite web |date=30 Mar 2021 |title=Epic Games files complaint to support CMA Apple investigation |url=https://www.epicgames.com/site/en-US/news/epic-games-files-complaint-to-support-cma-apple-investigation |url-status=live |access-date=16 Mar 2025 |website=[[Epic Games]]}}</ref> | |||
| On 11 September 2021, Judge Yvonne Gonzalez Rogers decided on the case. While the lawsuit against Apple failed on 9 of 10 counts, Rogers ruled against Apple's use of "anti-steering" - their strategies of preventing the user from being "steered" to a third-party storefront for payment processing, placing a permanent injunction on this behavior.<ref>{{Cite web |last=Brandon |first=Russell |date=11 Sep 2021 |title=Apple must allow other forms of in-app purchase, rules judge in Epic v. Apple |url=https://www.theverge.com/2021/9/10/22662320/epic-apple-ruling-injunction-judge-court-app-store |url-status=live |access-date=1 May 2025 |website=[[The Verge]]}}</ref> Despite the case mostly failing, the discovery process provided significant insight into Apple's decisions around App Store policies, including decisions made in major app review disputes, and in one case, executive Phil Schiller arguing to reduce the fee from 30%.<ref>{{Cite web |last=Gurman |first=Mark |date=4 May 2021 |title=Apple’s Schiller Floated Cutting App Store Fees a Decade Ago |url=https://www.bloomberg.com/news/articles/2021-05-03/apple-s-schiller-floated-cutting-app-store-fees-a-decade-ago |url-status=live |access-date=1 May 2025 |website=[[Bloomberg]]}}</ref> | |||
| Epic Games and Apple both appealed the decision. 35 state attorneys-general, the [[Electronic Frontier Foundation]] (EFF), [[Microsoft]], among others filed amicus briefs in support of Epic Games.<ref>{{Cite web |last=Peters |first=Jay |date=29 Jan 2022 |title=Epic largely lost to Apple, but 35 states are now backing its fight in a higher court |url=https://www.theverge.com/2022/1/28/22907106/epic-games-v-apple-amicus-briefs-states-eff-microsoft-appeal |url-status=live |access-date=1 May 2025 |website=[[The Verge]]}}</ref> | |||
| On 11 December 2023, the jury in the case against Google decided on all 11 counts in favor of Epic Games.<ref>{{Cite web |last=Bensinger |first=Greg |last2=Scarcella |first2=Mike |date=13 Dec 2023 |title=Epic Games wins antitrust case against Google over Play app store |url=https://www.reuters.com/legal/google-epic-games-face-off-app-antitrust-trial-nears-end-2023-12-11/ |url-status=live |access-date=1 May 2025 |website=[[Reuters]]}}</ref> | |||
| On 1 May 2025, Rogers found that Apple willfully chose to not comply with the 2021 injunction, commenting "that it thought this court would tolerate such insubordination was a gross miscalculation".<ref>{{Cite web |last=Peters |first=Jay |date=1 May 2025 |title=A judge just blew up Apple’s control of the App Store |url=https://www.theverge.com/news/659246/apple-epic-app-store-judge-ruling-control |url-status=live |access-date=1 May 2025 |website=[[The Verge]]}}</ref> | |||
| ===Facebook online events=== | ===Facebook online events=== | ||
| In August 2020, in response to the COVID-19 pandemic, Facebook introduced the ability for small businesses to accept an entrance fee for events. Previously, Facebook would only act as a way to RSVP for the event - the organizer must use a third-party event ticketing system to collect fees. The company pledged to not collect any fee on event sales "until 2023".<ref>https://about.fb.com/news/2020/08/paid-online-events/</ref> | In August 2020, in response to the COVID-19 pandemic, Facebook introduced the ability for small businesses to accept an entrance fee for events. Previously, Facebook would only act as a way to RSVP for the event - the organizer must use a third-party event ticketing system to collect fees. The company pledged to not collect any fee on event sales "until 2023".<ref>{{Cite web |date=14 Aug 2020 |title=Paid Online Events for Small Business Recovery |url=https://about.fb.com/news/2020/08/paid-online-events/ |url-status=live |access-date=16 Mar 2025 |website=[[Meta]]}}</ref> | ||
| Apple disagreed, requiring the feature to use the in-app purchases system. This introduced Apple's 30% fee. As this increases the price the user pays, with no benefit to the small business the user intended to support, the fee was displayed as a line item in checkout. Apple did not accept this disclosure of the fee, referring to it as "irrelevant".<ref name="facebook" /> Facebook was allowed to compromise on displaying the fee, but ''without'' indicating that it is specifically an App Store fee. | Apple disagreed, requiring the feature to use the in-app purchases system. This introduced Apple's 30% fee. As this increases the price the user pays, with no benefit to the small business the user intended to support, the fee was displayed as a line item in checkout. Apple did not accept this disclosure of the fee, referring to it as "irrelevant".<ref name="facebook" /> Facebook was allowed to compromise on displaying the fee, but ''without'' indicating that it is specifically an App Store fee. | ||
| Line 45: | Line 69: | ||
| HEY.com is a paid webmail provider launched in June 2020 by long-time software company [[wikipedia:37signals|37signals]], specializing in inbox organization tools. | HEY.com is a paid webmail provider launched in June 2020 by long-time software company [[wikipedia:37signals|37signals]], specializing in inbox organization tools. | ||
| After successfully launching the initial version of the app on the App Store, the company announced that an update was rejected due to a complaint about the business model. The app did not intend to support in-app purchases - instead, the user is expected to already have an account with the service. Apple did not like this arrangement, and demanded the company build an in-app subscription option. The company argued that they are being held to a different set of rules than apps such as [[Netflix]], whose app does not provide any way to purchase a subscription.<ref>https://www.theverge.com/2020/6/16/21293419/hey-apple-rejection-ios-app-store-dhh-gangsters-antitrust</ref> After a suggestion from Apple executive Phil Schiller in the media, HEY introduced a 14 day free trial mode, which was approved.<ref>https://www.hey.com/apple/path/</ref><ref>https://techcrunch.com/2020/06/18/interview-apples-schiller-says-position-on-hey-app-is-unchanged-and-no-rules-changes-are-imminent/</ref> | After successfully launching the initial version of the app on the App Store, the company announced that an update was rejected due to a complaint about the business model. The app did not intend to support in-app purchases - instead, the user is expected to already have an account with the service. Apple did not like this arrangement, and demanded the company build an in-app subscription option. The company argued that they are being held to a different set of rules than apps such as [[Netflix, Inc.|Netflix]], whose app does not provide any way to purchase a subscription.<ref>{{Cite web |last=Kastrenakes |first=Jacob |date=17 Jun 2020 |title=Hey.com exec says Apple is acting like ‘gangsters,’ rejecting App Store updates and demanding cut of sales |url=https://www.theverge.com/2020/6/16/21293419/hey-apple-rejection-ios-app-store-dhh-gangsters-antitrust |url-status=live |access-date=16 Mar 2025 |website=[[The Verge]]}}</ref> After a suggestion from Apple executive Phil Schiller in the media, HEY introduced a 14 day free trial mode, which was approved.<ref>https://www.hey.com/apple/path/</ref><ref>https://techcrunch.com/2020/06/18/interview-apples-schiller-says-position-on-hey-app-is-unchanged-and-no-rules-changes-are-imminent/</ref> | ||
| ===Patreon=== | ===Patreon=== | ||
| In August 2024, [[Patreon]] announced a change in arrangement with Apple for its App Store app. From November 2024, subscriptions started from the iOS app would be required to use the in-app purchase system, bypassing Patreon's own long-standing payments practices.<ref>https://news.patreon.com/articles/understanding-apple-requirements-for-patreon</ref><ref name="patreon" /> This change does not affect the Android app. | In August 2024, [[Patreon]] announced a change in arrangement with Apple for its App Store app. From November 2024, subscriptions started from the iOS app would be required to use the in-app purchase system, bypassing Patreon's own long-standing payments practices.<ref>{{Cite web |date=12 Aug 2024 |title=Apple’s requirements are about to hit creators and fans on Patreon. Here’s what you need to know. |url=https://news.patreon.com/articles/understanding-apple-requirements-for-patreon |url-status=live |access-date=16 Mar 2025 |website=[[Patreon]]}}</ref><ref name="patreon" /> This change does not affect the Android app. | ||
| By forcing Patreon out of the payments pipeline, certain payment models are no longer available to users of Patreon's iOS app. Creators who rely on the "per-creation" payment model, as opposed to the standard "per-month", can no longer be subscribed to from the app. The app is also not able to support the "first-of-the-month" model, where payments from all subscribers are collected on the first day of the month, rather than every 30 days since each member's day of subscription. The price must also be rounded to a price tier supported by Apple. | By forcing Patreon out of the payments pipeline, certain payment models are no longer available to users of Patreon's iOS app. Creators who rely on the "per-creation" payment model, as opposed to the standard "per-month", can no longer be subscribed to from the app. The app is also not able to support the "first-of-the-month" model, where payments from all subscribers are collected on the first day of the month, rather than every 30 days since each member's day of subscription. The price must also be rounded to a price tier supported by Apple. | ||
| Line 54: | Line 78: | ||
| Patreon provides creators with the choice to increase their prices by 30% in the iOS app, or to keep the same prices but forfeit 30% to Apple. Creators frequently remind potential supporters to not use the Patreon iOS app, adding extra inconvenience to those wanting to support the work of small creators. | Patreon provides creators with the choice to increase their prices by 30% in the iOS app, or to keep the same prices but forfeit 30% to Apple. Creators frequently remind potential supporters to not use the Patreon iOS app, adding extra inconvenience to those wanting to support the work of small creators. | ||
| <gallery mode="packed" heights=" | <gallery mode="packed" heights="400px"> | ||
| File:Patreon iOS app pricing options - fee on top.png|"Maintain earnings and cover Apple's fee by increasing prices in iOS app" (Recommended) | File:Patreon iOS app pricing options - fee on top.png|"Maintain earnings and cover Apple's fee by increasing prices in iOS app" (Recommended) | ||
| File:Patreon iOS app pricing options - absorb fee.png|"Keep prices in the iOS app the same and cover Apple's fee yourself" | File:Patreon iOS app pricing options - absorb fee.png|"Keep prices in the iOS app the same and cover Apple's fee yourself" | ||
| </gallery> | </gallery> | ||
| A similar case occurred with the app Fanhouse in 2021.<ref>https:// | A similar case occurred with the app Fanhouse in 2021.<ref>{{Cite web |last=@jasminericegirl |date=9 Jun 2021 |title=#fuckapple, a thread I cofounded @fanhouseapp 8 months ago to empower creators to monetize their content. We pay creators 90% of earnings. Now, Apple is threatening to remove Fanhouse from the app store unless we give them 30% of creator earnings. This is theft and exploitation. |url=https://x.com/jasminericegirl/status/1402691047940100100 |access-date=16 Mar 2025 |website=[[X]]}}</ref> | ||
| ===Twitter=== | ===Twitter=== | ||
| In August 2021, [[Twitter]] introduced a feature named Super Follows (now Subscriptions), in which a user can pay a subscription fee to access more of a creator's content. For each user who enables Subscriptions, Twitter must submit a new in-app purchase SKU to the App Store, which will become available with the next update to the app.<ref>https:// | In August 2021, [[Twitter]] introduced a feature named Super Follows (now Subscriptions), in which a user can pay a subscription fee to access more of a creator's content. For each user who enables Subscriptions, Twitter must submit a new in-app purchase SKU to the App Store, which will become available with the next update to the app.<ref>{{Cite web |last=@wongmjane |date=2 Sep 2021 |title=Each Super Follow is an In-App Purchase on the App Store, but because there are too many IAPs for the Twitter app, the App Store only shows 10 instead of the full list |url=https://x.com/wongmjane/status/1433372120080261120 |url-status=live |access-date=16 Mar 2025 |website=[[X]]}}</ref> This, of course, is subject to the 30% fee. At the time of writing in January 2025, viewing the App Store listing reveals Elon Musk's $4.00 subscription as the fourth most popular IAP item. | ||
| ==Notarization== | ==Notarization== | ||
| Line 68: | Line 92: | ||
| <blockquote> | <blockquote> | ||
| Notarization of macOS software is not App Review. The Apple notary service is an automated system that scans your software for malicious content, checks for code-signing issues, and returns the results to you quickly. If there are no issues, the notary service generates a ticket for you to staple to your software; the notary service also publishes that ticket online where Gatekeeper can find it.<ref>https://developer.apple.com/documentation/security/notarizing-macos-software-before-distribution</ref> | Notarization of macOS software is not App Review. The Apple notary service is an automated system that scans your software for malicious content, checks for code-signing issues, and returns the results to you quickly. If there are no issues, the notary service generates a ticket for you to staple to your software; the notary service also publishes that ticket online where Gatekeeper can find it.<ref>{{Cite web |title=Notarizing macOS software before distribution |url=https://developer.apple.com/documentation/security/notarizing-macos-software-before-distribution |url-status=live |access-date=16 Mar 2025 |website=[[Apple Developer]]}}</ref> | ||
| </blockquote> | </blockquote> | ||
| Line 83: | Line 107: | ||
| Apple is retaining complete control over what's allowed to run on iOS. On macOS, you can choose to run apps that have not been notarized (even though the process to bypass the warning is intentionally difficult). On iOS, you never get even that option. What Apple created is the App Store but with more steps. It still goes on the App Store, just hidden so it can only be installed by the third-party store it's tied to. | Apple is retaining complete control over what's allowed to run on iOS. On macOS, you can choose to run apps that have not been notarized (even though the process to bypass the warning is intentionally difficult). On iOS, you never get even that option. What Apple created is the App Store but with more steps. It still goes on the App Store, just hidden so it can only be installed by the third-party store it's tied to. | ||
| *Mysk: "iOS should enable alternative marketplaces to add their own links when users share their apps. Links still point to the App Store and if the app is not available there, this happens."<ref>https:// | *Mysk: "iOS should enable alternative marketplaces to add their own links when users share their apps. Links still point to the App Store and if the app is not available there, this happens."<ref>{{Cite web |last=@mysk_co |date=28 Jun 2024 |title=iOS should enable alternative marketplaces to add their own links when users share their apps. Links still point to the App Store and if the app is not available there, this happens: |url=https://x.com/mysk_co/status/1806638308455256242 |url-status=live |access-date=16 Mar 2025 |website=[[X]]}}</ref> | ||
| ==JIT== | ==JIT== | ||
| The following paragraph is highly technical, if it's too technical for you to understand all you need to know is that: JIT allows for extremely fast programs/apps and due to its fast nature it's used almost everywhere, and is a massive improvement over older code interpreters. | |||
| [[wikipedia:Just-in-time compilation|JIT]], which stands for Just-In-Time, is a method of code execution where code, instead of being compiled before being distributed (like an EXE), gets compiled into machine code in real time right before being executed. This method of code execution allows for much faster website loading times, faster emulation, faster program execution (with programs written in JavaScript, Python, Lua...) compared to interpreters, which instead translates code into machine code line by line, which is much, much slower; JIT also employs many more optimization techniques meant to improve performance. | |||
| Safari is allowed to use JIT to compile code from any site, same with Apple's [https://apps.apple.com/app/swift-playgrounds/id908519492 Playgrounds] app on iPad. Playgrounds bundles Apple's [[wikipedia:Swift (programming language)|Swift]] compiler, and shares backend code with the version of Playgrounds found in [[wikipedia:Xcode|Xcode]]. | |||
| Third-party apps like Pythonista (a Python IDE), emulators like Delta and UTM and terminal environments like iSH are not allowed to use JIT, instead having to interpret code, which comes with serious performance degradation and is more computationally expensive, potentially draining more battery. | |||
| An example of apps being heavily affected by this restriction is UTM. UTM is a port of [[wikipedia:QEMU|QEMU]] for iOS, iPadOS and MacOS, allowing users to create [[wikipedia:Virtual_machine|VMs]] that can run various OSes, for example Microsoft Windows. The iPhone's hardware capable enough to emulate various modern OSes at full speed, but due to Apple's JIT limitation, the team behind UTM had to create UTM SE (slow edition) that doesn't require JIT, but is nowhere near as fast as UTM with JIT, only being capable of running MS-DOS and derivatives at acceptable speeds. While methods that enable JIT for apps other than Safari and Playgrounds exist (some currently working on iOS 18.5, like [https://apps.apple.com/us/app/stikdebug/id6744045754 StikDebug]), Apple does not allow the use of JIT in notarized apps, meaning that apps that support JIT will have to be sideloaded, which comes with its own set of restrictions. | |||
| In the EU, Apple gave web browsers permission to use rendering and JavaScript engines other than the built-in with Apple WebKit/JavaScriptCore, with the option for JS engines to use JIT. The browser still has to be approved by Apple for an entitlement, and then must work within APIs provided by Apple for it. But, as of January 2025, no browsers that use different engines than the built-in ones have been released, mainly due to arbitrarily imposed restrictions, meant to discourage the usage and development of third-party engines.<ref>{{Cite web |title=Mozilla says Apple’s new browser rules are ‘as painful as possible’ for Firefox |url=https://www.theverge.com/2024/1/26/24052067/mozilla-apple-ios-browser-rules-firefox |url-status=live |access-date=16 Mar 2025 |website=[[The Verge]]}}</ref> | |||
| However, Apple still does not allow different engines outside of the EU, with or without JIT support.<ref>{{Cite web |title=App Review Guidelines |url=https://developer.apple.com/app-store/review/guidelines/#2.5.6 |url-status=live |access-date=16 Mar 2025 |website=[[Apple Developer]]}}</ref>   | |||
| ==Sandbox== | ==Sandbox== | ||
| Sandboxing is a powerful security feature used on all modern platforms, from Windows to iOS, and it's used because most programs need only a few basic permissions. While sandboxing is a great security measure, sometimes users may want to develop or create programs that run outside of the sandbox, with less restrictions. When a program needs extra permissions outside of what the sandbox normally allows, the user is prompted with a permission prompt, useful when some very basic programs (like a flashlight app) need access to sensitive information like contacts. | |||
| As established in previous sections, a program can be given more access to features of the system using entitlements. These come in different types: | |||
| *'''Completely safe''': Entitlements any developer can opt into, with little to no risk. | *'''Completely safe''': Entitlements any developer can opt into, with little to no risk. | ||
| *'''Approval required''': Entitlements that might be more of a security risk to allow, e.g. giving considerably wider access to the system, or that Apple simply doesn't want to hand out to just ''anyone'' for competitive reasons. The developer must submit a request to Apple with evidence of why they need the entitlement. | *'''Approval required''': Entitlements that might be more of a security risk to allow, e.g. giving considerably wider access to the system, or that Apple simply doesn't want to hand out to just ''anyone'' for competitive reasons. The developer must submit a request to Apple with evidence of why they need the entitlement. | ||
| *'''Private''': Entitlements that are never allowed for any app developer to use. Many of these are reasonably fenced off because they handle user data that is very risky, or bypasses permission prompts | *'''Private''': Entitlements that are never allowed for any app developer to use. Many of these are reasonably fenced off because they handle user data that is very risky, or bypasses permission prompts and so on, but can just as well also be guarding features Apple wants to keep to itself. | ||
| There have been [https://gizmodo.com/researchers-uber-s-ios-app-had-secret-permissions-that-1819177235 exceptions] where Apple quietly gave a company access to private entitlements anyway, raising eyebrows. | There have been [https://gizmodo.com/researchers-uber-s-ios-app-had-secret-permissions-that-1819177235 exceptions] where Apple quietly gave a company access to private entitlements anyway, raising eyebrows. | ||
| On iOS, you also can't be ''more'' secure than the default sandbox | On iOS, you also can't be ''more'' secure than the default, strictest sandbox. On macOS, there are several entitlements you must declare to decide whether you're allowed to access certain types of user data at all. Android used this design from the very start - you can't even do fundamental things like access the internet without declaring it in your manifest. It makes it very explicit what the app's intentions are. | ||
| iOS has one sandbox used by all App Store apps. System apps, and App Store apps developed by Apple, are allowed to expand or reduce their sandbox permissions as needed. Third-party apps do not get the right to expand or reduce their sandbox permissions at all. This is clearly less secure. To take the example of Playgrounds again, while it's allowed to run your code from a separate process executing in an ultra locked down sandbox with very few permissions, competing apps such as Pythonista must run your code in the same sandbox and address space as the main app process. The Python interpreter crashing would therefore crash the entire app, possibly losing work. In the worst case, a vulnerability in third-party code could give access to all data stored by/accessible to the app. For example, it would be a nightmare if you can tap the wrong link in Safari and have a hacker easily steal your cookies from other websites. If that third-party code could run in its own limited sandbox, the risk is significantly reduced. | iOS has one sandbox used by all App Store apps. System apps, and App Store apps developed by Apple, are allowed to expand or reduce their sandbox permissions as needed. Third-party apps do not get the right to expand or reduce their sandbox permissions at all. This is clearly less secure. To take the example of Playgrounds again, while it's allowed to run your code from a separate process executing in an ultra locked down sandbox with very few permissions, competing apps such as Pythonista must run your code in the same sandbox and address space as the main app process. The Python interpreter crashing would therefore crash the entire app, possibly losing work. In the worst case, a vulnerability in third-party code could give access to all data stored by/accessible to the app. For example, it would be a nightmare if you can tap the wrong link in Safari and have a hacker easily steal your cookies from other websites. If that third-party code could run in its own limited sandbox, the risk is significantly reduced. | ||
| Line 114: | Line 142: | ||
| ==In-app browsers== | ==In-app browsers== | ||
| Safari's in-app browser, that is the minimal version you get when tapping a link from social media, uses an entirely separate data store for each app. The in-app browser isn't aware of cookies in the "full" Safari app, or any other app, and doesn't support Safari extensions. Apple claimed this was to protect malicious apps from stealing or setting cookies in Safari without your knowledge, which is a fair argument, but it's hard to not notice that it makes web browsing inconvenient, encouraging users to install native apps, where they can make transactions through Apple.<ref>https://github.com/openid/AppAuth-iOS/issues/120</ref> | Safari's in-app browser, that is the minimal version you get when tapping a link from social media, uses an entirely separate data store for each app. The in-app browser isn't aware of cookies in the "full" Safari app, or any other app, and doesn't support Safari extensions. Apple claimed this was to protect malicious apps from stealing or setting cookies in Safari without your knowledge, which is a fair argument, but it's hard to not notice that it makes web browsing inconvenient, encouraging users to install native apps, where they can make transactions through Apple.<ref>{{Cite web |last=@whitehatguy |date=12 Jun 2017 |title=Impact of iOS 11 no longer providing shared cookies between Safari, Safari View Controller instances |url=https://github.com/openid/AppAuth-iOS/issues/120 |url-status=live |access-date=16 Mar 2025 |website=[[GitHub]]}}</ref> | ||
| This also means your browsing in the in-app browser is just forgotten - there's no history menu, and it doesn't get logged to the history in the full Safari app either. Good luck recalling that article you read a few weeks ago. | This also means your browsing in the in-app browser is just forgotten - there's no history menu, and it doesn't get logged to the history in the full Safari app either. Good luck recalling that article you read a few weeks ago. | ||