Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/MicrosoftEdge/hwa-cli
Command-Line Interface for converting Windows Hosted Web Apps locally and remotely
https://github.com/MicrosoftEdge/hwa-cli
Last synced: about 1 month ago
JSON representation
Command-Line Interface for converting Windows Hosted Web Apps locally and remotely
- Host: GitHub
- URL: https://github.com/MicrosoftEdge/hwa-cli
- Owner: MicrosoftEdge
- License: mit
- Archived: true
- Created: 2015-09-10T00:49:09.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2016-07-28T06:31:29.000Z (over 8 years ago)
- Last Synced: 2024-11-20T20:12:17.804Z (about 1 month ago)
- Language: TypeScript
- Homepage:
- Size: 128 KB
- Stars: 31
- Watchers: 8
- Forks: 17
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# hwa-cli
## Convert your Chrome app to a Windows hosted app
1. Install [NodeJS and npm](https://nodejs.org/en/)
1. Open a command prompt window to the directory of your choice
1. Install hwa cli: `npm i -g hwa-cli`
1. Convert your [Chrome package](#supported-chrome-package-formats): `hwa convert path/to/chrome/app.crx` or `hwa convert path/to/chrome/app.zip`
1. Fill out the [Windows Store prompts](#how-to-fill-out-the-windows-store-prompts)
1. The generated `.appx` will appear in the same folder as your Chrome package.You are now ready to [upload](https://dev.windows.com) your Hosted Web App to the Windows Store. Upload your AppX package by navigating to the "Packages" page in the Submissions section.
Be sure to [check out the guide below](#guide-for-migrating-your-hosted-web-app) for more information on migrating your Hosted Web App.
### Supported Chrome package formats
The following package formats are supported: `.crx`, `.zip`.### How to fill out the Windows Store prompts
During the conversion process, you will be prompted for an Identity Name, Publisher Identity, and Publisher Display Name. To retrieve these values, visit the Dashboard in the [Windows Dev Center](https://dev.windows.com/).1. Click on "Create a new app" and reserve your [app name](https://cloud.githubusercontent.com/assets/3271834/11040454/3780d02a-86c1-11e5-90b1-4775a66f7247.png).
2. Next, click on "[App identity](https://cloud.githubusercontent.com/assets/3271834/11040490/640fd870-86c1-11e5-9821-85e411fd747e.png)" in the menu on the left under the "App management" section.
3. You should see the [three values](https://cloud.githubusercontent.com/assets/3271834/11041022/3050589a-86c4-11e5-9ce5-5985b81c97a3.png) for which you are prompted listed on the page.
* Identity Name: `Package/Identity/Name`
* Publisher Identity: `Package/Identity/Publisher`
* Publisher Display Name: `Package/Properties/PublisherDisplayName`## Guide for migrating your Hosted Web App
### Things you should know
* [Application Content URI Rules](#application-content-uri-rules)
* [Flash](#flash)
* [Image assets](#image-assets)
* [Capabilities](#capabilities)
* [File downloads](#file-downloads)
* [Chrome platform APIs](#chrome-platform-apis)### Application Content URI Rules
[Application Content URI Rules](http://microsoftedge.github.io/WebAppsDocs/en-US/win10/HWAfeatures.htm#keep-your-app-secure----setting-application-content-uri-rules-acurs) (ACURs) or Content URIs define the scope of your Hosted Web App through a URL allow list in your app package manifest. In order to control the communication to and from remote content, you must define which URLs are included in, and/or excluded from, this list. If a user clicks a URL that is not explicitly included, Windows will open the target path in the default browser. With ACURs, you are also able to grant a URL access to [Universal Windows APIs](https://msdn.microsoft.com/en-us/library/windows/apps/br211377.aspx).At the very minimum, your rules should include your app’s start page. The conversion tool will automatically create a set of ACURs for you, based on your start page and its domain. However, if there are any programmatic redirects, whether on the server or on the client, those destinations will need to be added to the allow list.
Note: ACURs only apply to page navigation. Images, JavaScript libraries, and other similar assets are not affected by these restrictions.
Many apps use third-party sites for their login flows, e.g. Facebook and Google. The conversion tool will automatically create a set of ACURs for you, based on the most popular sites. If your method of authentication is not included in that list, and it’s a redirect flow, you will need to add its path(s) as an ACUR. You can also consider using a [web authentication broker](http://microsoftedge.github.io/WebAppsDocs/en-US/win10/HWAfeatures.htm#web-authentication-broker).
### Flash
Flash is not allowed in Windows 10 apps. You will need to make sure your app experience is not affected by its absence.For ads, you will need to make sure your ad provider has an HTML5 option. You can check out [Bing Ads](https://bingads.microsoft.com/) and [Ads in Apps](http://adsinapps.microsoft.com/).
YouTube videos should still work, as they now [default to HTML5 <video>](http://youtube-eng.blogspot.com/2015/01/youtube-now-defaults-to-html5_27.html), so long as you are using the [<iframe> embed method](https://developers.google.com/youtube/iframe_api_reference). If your app still uses the Flash API, you will need to switch to the aforementioned style of embed.
### Image assets
The Chrome web store already [requires](https://developer.chrome.com/webstore/images) a 128x128 app icon image in your app package. For Windows 10 apps, you must supply 44x44, 50x50, 150x150, and 600x350 app icon images, at the very minimum. The conversion tool will automatically create these images for you, based on the 128x128 image. For a richer, more polished app experience, we highly recommend creating your own image files. Here are some [guidelines](https://msdn.microsoft.com/en-us/library/windows/apps/mt412102.aspx) for tile and icon assets.### Capabilities
App capabilities must be [declared](https://msdn.microsoft.com/en-us/library/windows/apps/Mt270968.aspx) in your package manifest in order to access certain APIs and resources. The conversion tool will automatically enable three popular device capabilities for you: location, microphone, and webcam. With the former, the system will still prompt the user for permission before granting access.Note: Users are notified of all the capabilities that an app declares. We would recommend removing any capabilities that your app does not need.
### File downloads
Traditional file downloads, like you see in the browser, are not currently supported.### Chrome platform APIs
Chrome provides apps with [special-purpose APIs](https://developer.chrome.com/apps/api_index) that can be run as background script. These are not supported. You can find equivalent functionality, and much more, with the [Windows Runtime APIs](https://msdn.microsoft.com/en-us/library/windows/apps/br211377.aspx).## Accessing Windows features
For more information, [visit this page](http://microsoftedge.github.io/WebAppsDocs/en-US/win10/HWAfeatures.htm).## Code of Conduct
This project has adopted the [Microsoft Open Source Code of Conduct](https://opensource.microsoft.com/codeofconduct/). For more information see the [Code of Conduct FAQ](https://opensource.microsoft.com/codeofconduct/faq/) or contact [[email protected]](mailto:[email protected]) with any additional questions or comments.