File: nsIWindowsPackageManager.idl

package info (click to toggle)
firefox 147.0.3-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 4,683,320 kB
  • sloc: cpp: 7,607,359; javascript: 6,533,295; ansic: 3,775,223; python: 1,415,500; xml: 634,561; asm: 438,949; java: 186,241; sh: 62,752; makefile: 18,079; objc: 13,092; perl: 12,808; yacc: 4,583; cs: 3,846; pascal: 3,448; lex: 1,720; ruby: 1,003; php: 436; lisp: 258; awk: 247; sql: 66; sed: 54; csh: 10; exp: 6
file content (47 lines) | stat: -rw-r--r-- 2,124 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
/* -*- Mode: IDL; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/* This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */

#include "nsISupports.idl"

[scriptable, uuid(ad57ac40-52f0-11ec-ada8-4f671255c4aa)]
interface nsIWindowsPackageManager : nsISupports
{
/* Searches for any user installed MSIX packages whose
 * packageFamilyName matches any of the provided `aNamePrefixes`
 * and returns them. The Windows APIs only allow querying user
 * installed packages without elevation, so this will not see any
 * packages installed by another user.
 */
    Array<AString> findUserInstalledPackages(in Array<AString> prefix);

/* When running within a Packaged App environment, returns the
 * InstalledDate of the Package. If called when not running within
 * a Packaged App environment, throws NS_ERROR_NOT_IMPLEMENTED.
 * Any other others will cause NS_ERROR_FAILURE to be thrown.
 */
    unsigned long long getInstalledDate();

/* Asynchronously retrieves the campaignId, if any, a user's Microsoft Store
 * install is associated with.
 *
 * These are present if the user clicked a "ms-window-store://" or "https://"
 * link that included a "cid" query argument the very first time they installed
 * the app. These are also present if the user installed through a Microsoft
 * Store Ad, which results in non-URL encoded string `storeBingAd_[uuid]` (This
 * value appears to be cached forever, so subsequent installs will not refresh
 * it.)
 *
 * If a non-empty campaign ID is found it will be assumed to be a properly
 * formatted attribution code and have an additional "msstoresignedin" key
 * appended to it indicate whether or not the user was signed in when they
 * installed the application. This key will either be set to "true" or "false".
 *
 * @throw NS_ERROR_NOT_IMPLEMENTED if called on Windows 8 or earlier, or from
 * a non-packaged build.
 * @throw NS_ERROR_FAILURE for any other errors
 */
    [implicit_jscontext]
    Promise campaignId();
};