forked from mirrors/gecko-dev
		
	 3c0c3a2676
			
		
	
	
		3c0c3a2676
		
	
	
	
	
		
			
			This patch was generated as follows: Run: `./mach esmify --imports . --prefix=toolkit/mozapps/extensions/AddonManager` In the output there are linter/prettifier errors due to unused XPCOMUtils or separate importESModule calls. These have been fixed manually and verified with `./mach lint --outgoing`. The `esmify` script also inserts many unwanted newlines around imports that are broken on two lines due to length. Due to the number of these, I fixed them programatically. 1. Create patch from the changes so far. 2. From the patch, delete all lines that consist of "+" (i.e. added blank line). 3. Reset the working dir and apply the revised patch. 4. Verify that the diff between step 1 and 3 looks reasonable. 5. Verify that this patch as a whole looks reasonable. Commands: ``` git diff > rename.diff :%g/^+$/d git commit -va -m WIP-rename git revert HEAD git apply --recount rename.diff git diff HEAD^ # and verify that the removed lines are ok. git commit -va # one last review to verify correctness of whole patch. git rebase -i HEAD~3 # drop the WIP + reverted commit, pick only the last. ``` `git apply` has the `--recount` option to force it to ignore mismatches in line counts, which happens because we deleted added lines (^+$) without fixing up the line counts in the file headers. Differential Revision: https://phabricator.services.mozilla.com/D179874
		
			
				
	
	
		
			84 lines
		
	
	
	
		
			2.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			84 lines
		
	
	
	
		
			2.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| /* 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/. */
 | |
| 
 | |
| "use strict";
 | |
| 
 | |
| const { AddonStudies } = ChromeUtils.importESModule(
 | |
|   "resource://normandy/lib/AddonStudies.sys.mjs"
 | |
| );
 | |
| const { ClientID } = ChromeUtils.importESModule(
 | |
|   "resource://gre/modules/ClientID.sys.mjs"
 | |
| );
 | |
| 
 | |
| ChromeUtils.defineESModuleGetters(this, {
 | |
|   AddonManager: "resource://gre/modules/AddonManager.sys.mjs",
 | |
| });
 | |
| 
 | |
| this.normandyAddonStudy = class extends ExtensionAPI {
 | |
|   getAPI(context) {
 | |
|     let { extension } = context;
 | |
| 
 | |
|     return {
 | |
|       normandyAddonStudy: {
 | |
|         /**
 | |
|          * Returns a study object for the current study.
 | |
|          *
 | |
|          * @returns {Study}
 | |
|          */
 | |
|         async getStudy() {
 | |
|           const studies = await AddonStudies.getAll();
 | |
|           return studies.find(study => study.addonId === extension.id);
 | |
|         },
 | |
| 
 | |
|         /**
 | |
|          * Marks the study as ended and then uninstalls the addon.
 | |
|          *
 | |
|          * @param {string} reason Why the study is ending
 | |
|          */
 | |
|         async endStudy(reason) {
 | |
|           const study = await this.getStudy();
 | |
| 
 | |
|           // Mark the study as ended
 | |
|           await AddonStudies.markAsEnded(study, reason);
 | |
| 
 | |
|           // Uninstall the addon
 | |
|           const addon = await AddonManager.getAddonByID(study.addonId);
 | |
|           if (addon) {
 | |
|             await addon.uninstall();
 | |
|           }
 | |
|         },
 | |
| 
 | |
|         /**
 | |
|          * Returns an object with metadata about the client which may
 | |
|          * be required for constructing survey URLs.
 | |
|          *
 | |
|          * @returns {object}
 | |
|          */
 | |
|         async getClientMetadata() {
 | |
|           return {
 | |
|             updateChannel: Services.appinfo.defaultUpdateChannel,
 | |
|             fxVersion: Services.appinfo.version,
 | |
|             clientID: await ClientID.getClientID(),
 | |
|           };
 | |
|         },
 | |
| 
 | |
|         onUnenroll: new EventManager({
 | |
|           context,
 | |
|           name: "normandyAddonStudy.onUnenroll",
 | |
|           register: fire => {
 | |
|             const listener = async reason => {
 | |
|               await fire.async(reason);
 | |
|             };
 | |
| 
 | |
|             AddonStudies.addUnenrollListener(extension.id, listener);
 | |
| 
 | |
|             return () => {
 | |
|               AddonStudies.removeUnenrollListener(extension.id, listener);
 | |
|             };
 | |
|           },
 | |
|         }).api(),
 | |
|       },
 | |
|     };
 | |
|   }
 | |
| };
 |