From 0fe51b68a1907c38187cbba3f37df4a51350dd48 Mon Sep 17 00:00:00 2001 From: Sebastien Pouliot Date: Mon, 9 Dec 2024 16:47:27 -0500 Subject: [PATCH 1/3] chore: add dmgbuild to word spelling to ignore --- build/cSpell.json | 1 + 1 file changed, 1 insertion(+) diff --git a/build/cSpell.json b/build/cSpell.json index 53432b651001..c62cc3d5e86d 100644 --- a/build/cSpell.json +++ b/build/cSpell.json @@ -28,6 +28,7 @@ "devs", "dbus", "Dismissable", + "dmgbuild", "Docfx", "ellipsize", "Entra", From a666cab01032d12c10b7d2d61bf8f641566a30c4 Mon Sep 17 00:00:00 2001 From: Sebastien Pouliot Date: Tue, 10 Dec 2024 09:57:36 -0500 Subject: [PATCH 2/3] chore: Apply suggestions from review Co-authored-by: Andres Pineda <1900897+ajpinedam@users.noreply.github.com> --- .../uno-publishing-desktop-macos-advanced.md | 14 +++++----- doc/articles/uno-publishing-desktop-macos.md | 26 +++++++++---------- 2 files changed, 20 insertions(+), 20 deletions(-) diff --git a/doc/articles/uno-publishing-desktop-macos-advanced.md b/doc/articles/uno-publishing-desktop-macos-advanced.md index 07334d7a1a0e..c1e5728cc599 100644 --- a/doc/articles/uno-publishing-desktop-macos-advanced.md +++ b/doc/articles/uno-publishing-desktop-macos-advanced.md @@ -61,7 +61,7 @@ You can create a basic `Info.plist` file yourself, using any text editor. The co ``` -You can edit the `Info.plist` file, add any required entries (for permissions), and let other fields empty. The basic, empty fields will be filled automatically by the `msbuild` task based on your project. +You can edit the `Info.plist` file, add any required entries (for permissions), and leave other fields empty. The basic, empty fields will be filled automatically by the `msbuild` task based on your project. Then from the CLI run: @@ -102,7 +102,7 @@ dotnet publish -f net8.0-desktop -p:SelfContained=true -p:PackageFormat=app -p:U ### Trimming -App bundles that are distributed should be self-contained applications that depends only on the OS to execute. However bundling the dotnet runtime, base class libraries and Uno Platform libraries produce a rather large application size. +App bundles that are distributed should be self-contained applications that depend only on the OS to execute. However bundling the dotnet runtime, base class libraries and Uno Platform libraries produce a rather large application size. To reduce the size of the app bundle you can enable dotnet's [trimming](https://learn.microsoft.com/en-us/dotnet/core/deploying/trimming/trimming-options#enable-trimming) when publishing the app, using `-p:PublishTrimmed=true`. The full command from the CLI would be: @@ -115,11 +115,11 @@ dotnet publish -f net8.0-desktop -p:SelfContained=true -p:PackageFormat=app -p:P ### Optional files -`dotnet publish` include several files that are not strictly required to execute your application. To reduce the app bundle size most of those files are **not** included, by default, inside the app bundles. +`dotnet publish` includes several files that are not strictly required to execute your application. To reduce the app bundle size most of those files are **not** included, by default, inside the app bundles. #### Including dotnet `createdump` tool -Useful for debugging, the `createdump` executable is rarely used by the consumers of the application and, by default, is not included in the app bundle. +Although useful for debugging, the `createdump` executable is rarely used by the application's consumers and, by default, is not included in the app bundle. If you wish to include `createdump` inside your app bundle add the `-p:UnoMacOSIncludeCreateDump=true` on the CLI. @@ -149,9 +149,9 @@ dotnet publish -f net8.0-desktop -p:SelfContained=true -p:PackageFormat=app -p:U #### Including assemblies debugging symbols (.pdb) files -dotnet debugging symbols (`.pdb`) are generally included in released applications since it helps to provide better stack trace and help developers resolving issues. As such they are, by default, included inside the app bundle. +dotnet debugging symbols (`.pdb`) are generally included in released applications since they help to provide better stack traces and help developers resolve issues. As such, they are, by default, included inside the app bundle. -If you wish to remove them anyway you can do so by adding the `-p:UnoMacOSIncludeDebugSymbols=false` on the CLI. +If you wish to remove them anyway, you can do so by adding the `-p:UnoMacOSIncludeDebugSymbols=false` on the CLI. ```bash dotnet publish -f net8.0-desktop -p:SelfContained=true -p:PackageFormat=app -p:UnoMacOSIncludeDebugSymbols=false @@ -169,7 +169,7 @@ dotnet publish -f net8.0-desktop -p:SelfContained=true -p:PackageFormat=dmg -p:U ### Additional Customization -Further disk image customization is possible but can be tricky since it requires modification to the `.DS_Store` binary file inside the disk image (a lot of trials and errors). If more control is required (e.g. icon positioning, background image...) we recommend the use of 3rd party tools created specifically for this purpose. Some free/open source examples are: +Further disk image customization is possible but can be tricky since it requires modification to the `.DS_Store` binary file inside the disk image (many trials and errors). If more control is required (e.g. icon positioning, background image...) we recommend using 3rd party tools created specifically for this purpose. Some free/open source examples are: - [create-dmg](https://github.com/sindresorhus/create-dmg) - [dmgbuild](https://dmgbuild.readthedocs.io/en/latest/) diff --git a/doc/articles/uno-publishing-desktop-macos.md b/doc/articles/uno-publishing-desktop-macos.md index 573f8be59299..67ee788a24a7 100644 --- a/doc/articles/uno-publishing-desktop-macos.md +++ b/doc/articles/uno-publishing-desktop-macos.md @@ -40,14 +40,14 @@ To ensure the integrity of the app bundle Apple requires you to digitally sign y dotnet publish -f net8.0-desktop -r osx-arm64 -p:SelfContained=true -p:PackageFormat=app -p:CodesignKey={{identity}} ``` -You can use the special identity `-` to produce an adhoc signature. This basically tells macOS's [Gatekeeper](https://support.apple.com/en-us/102445) that the file is safe to use **locally**, however this does not help for distributing the app bundle. +You can use the special identity `-` to produce an adhoc signature. This basically tells macOS's [Gatekeeper](https://support.apple.com/en-us/102445) that the file is safe to use **locally**, however, it does not help distribute the app bundle. > [!NOTE] > Beside needed access to the Internet the code signing process slows down the builds. For local testing of your app you do not need to sign the app bundle. #### How to find your identity -If you have not already you need to create your [developer certificates](https://developer.apple.com/help/account/create-certificates/create-developer-id-certificates/). Once you have created on your Mac computer them you can find your identities, from the CLI, by running: +If you have not already, you need to create your [developer certificates](https://developer.apple.com/help/account/create-certificates/create-developer-id-certificates/). Once you have created them, on your Mac computer, you can find your identities from the CLI, by running: ```bash security find-identity -v @@ -91,10 +91,10 @@ From the CLI run: dotnet publish -f net8.0-desktop -r {{RID}} -p:SelfContained=true -p:PackageFormat=pkg -p:CodesignKey={{identity}} -p:PackageSigningKey={{installer_identity}} ``` -Where the following changes to the previous command are +Where the following changes to the previous command are: -- modifying `PackageFormat` to `pkg` to produce the package. This package will include the the app bundle inside it, so the `CodesignKey` argument is still required; -- adding `-p:PackageSigningKey={{installer_identity}}` to specify which identity should be used to sign the package. Unlike app bundles the signing step requires the use of a `Developer ID Installer: *` identity. +- modifying `PackageFormat` to `pkg` to produce the package. This package will include the app bundle inside it, so the `CodesignKey` argument is still required; +- adding `-p:PackageSigningKey={{installer_identity}}` to specify which identity should be used to sign the package. Unlike app bundles, signing requires a `Developer ID Installer: *` identity. The resulting installer will be located at `bin/Release/net8.0-desktop/{{RID}}/publish/{{APPNAME}}.pkg`. @@ -103,9 +103,9 @@ The resulting installer will be located at `bin/Release/net8.0-desktop/{{RID}}/p #### Notarize the package -Having both the app bundle (.app) and installer (.pkg) signed is not quite enough. As the package is a binary that you'll share with customers it needs to be notarized by Apple. +Having both the app bundle (.app) and installer (.pkg) signed is insufficient. As the package is binary and you'll share it with customers, Apple must also notarize it. -The first step is the store your Apple Account credentials inside the key store. This makes all the further commands (and notarization) much simpler. From the CLI run: +The first step is to store your Apple Account credentials inside the key store. This makes all the further commands (and notarization) much simpler. From the CLI run: ```bash xcrun notarytool store-credentials {{notarytool-credentials}} --apple-id john.appleby@platform.uno --team-id XXXXXXXXXX --password aaaa-bbbb-cccc-dddd @@ -130,7 +130,7 @@ Credentials saved to Keychain. To use them, specify `--keychain-profile "notarytool-credentials"` ``` -Once this (one time) setup is done you can notarize the disk image while building the app. From the CLI run: +Once this (one-time) setup is done, you can notarize the disk image while building the app. From the CLI run: ```bash dotnet publish -f net8.0-desktop -r {{RID}} -p:SelfContained=true -p:PackageFormat=dmg -p:CodesignKey={{identity}} -p:PackageSigningKey={{installer_identity}} -p:UnoMacOSNotarizeKeychainProfile={{notarytool-credentials}} -bl @@ -158,8 +158,8 @@ dotnet publish -f net8.0-desktop -r {{RID}} -p:SelfContained=true -p:PackageForm Where the following changes to the original command are -- modifying `PackageFormat` to `dmg` to produce the disk image. This image will include the the app bundle inside it, so the `CodesignKey` argument is still required; -- adding `-p:DiskImageSigningKey={{identity}}` to specify which identity should be used to sign the package. Like app bundles the signing step requires the use of a `Developer ID Application: *` identity. +- modifying `PackageFormat` to `dmg` to produce the disk image. This image will include the app bundle inside it, so the `CodesignKey` argument is still required; +- adding `-p:DiskImageSigningKey={{identity}}` to specify which identity should be used to sign the package. Like app bundles, the signing step requires using a `Developer ID Application: *` identity. The resulting disk image will be located at `bin/Release/net8.0-desktop/{{RID}}/publish/{{APPNAME}}.dmg`. @@ -167,7 +167,7 @@ The resulting disk image will be located at `bin/Release/net8.0-desktop/{{RID}}/ Like an installer (.pkg) a disk image is the outermost container that you'll share with customers and, as such, needs to be notarized by Apple. -The first step is the store your Apple Account credentials inside the key store. This makes all the further commands (and notarization) much simpler. From the CLI run: +The first step is to store your Apple Account credentials inside the key store. This makes all the further commands (and notarization) much simpler. From the CLI run: ```bash xcrun notarytool store-credentials {{notarytool-credentials}} --apple-id john.appleby@platform.uno --team-id XXXXXXXXXX --password aaaa-bbbb-cccc-dddd @@ -192,7 +192,7 @@ Credentials saved to Keychain. To use them, specify `--keychain-profile "notarytool-credentials"` ``` -Once this (one time) setup is done you can notarize the disk image while building the app. From the CLI run: +Once this (one-time) setup is done, you can notarize the disk image while building the app. From the CLI run: ```bash dotnet publish -f net8.0-desktop -r {{RID}} -p:SelfContained=true -p:PackageFormat=dmg -p:CodesignKey={{identity}} -p:DiskImageSigningKey={{identity}} -p:UnoMacOSNotarizeKeychainProfile={{notarytool-credentials}} -bl @@ -211,7 +211,7 @@ Once completed you can distribute the notarized disk image. ### Mac App Store > [!IMPORTANT] -> Application distributed on the Mac App Store are required to execute under a [sandbox](https://developer.apple.com/documentation/security/app-sandbox?language=objc) which impose additional limits on how applications can interact with the computer. +> Applications distributed on the Mac App Store are required to execute under a [sandbox](https://developer.apple.com/documentation/security/app-sandbox?language=objc), which imposes additional limits on how applications can interact with the computer. An app bundle (.app) can be submitted to Apple's [App Store](https://www.apple.com/app-store/) using the [transporter app](https://developer.apple.com/help/app-store-connect/manage-builds/upload-builds) from a computer running macOS. From 4aded963965854915ef87ff9ffa09aff0be8bbf6 Mon Sep 17 00:00:00 2001 From: Sebastien Pouliot Date: Wed, 11 Dec 2024 09:29:14 -0500 Subject: [PATCH 3/3] chore: fix _bad_ merge from master that removed some changes --- doc/articles/toc.yml | 11 ++- doc/articles/uno-publishing-desktop.linux.md | 76 +++++++++++++++++ doc/articles/uno-publishing-desktop.md | 90 -------------------- 3 files changed, 86 insertions(+), 91 deletions(-) create mode 100644 doc/articles/uno-publishing-desktop.linux.md diff --git a/doc/articles/toc.yml b/doc/articles/toc.yml index 481d4237870c..0d7eb6b6559f 100644 --- a/doc/articles/toc.yml +++ b/doc/articles/toc.yml @@ -268,7 +268,16 @@ - name: Overview href: xref:uno.publishing.overview - name: Publishing for Desktop - href: xref:uno.publishing.desktop + topicHref: xref:uno.publishing.desktop + items: + - name: Publishing Your App for Desktop + href: xref:uno.publishing.desktop + - name: Publishing Your App for macOS + href: xref:uno.publishing.desktop.macos + - name: Publishing Your App for macOS - Advanced Topics + href: xref:uno.publishing.desktop.macos.advanced + - name: Publishing Your App for Linux + href: xref:uno.publishing.desktop.linux - name: Publishing for WebAssembly href: xref:uno.publishing.webassembly - name: Publishing for Windows App SDK diff --git a/doc/articles/uno-publishing-desktop.linux.md b/doc/articles/uno-publishing-desktop.linux.md new file mode 100644 index 000000000000..0cd6e61e227b --- /dev/null +++ b/doc/articles/uno-publishing-desktop.linux.md @@ -0,0 +1,76 @@ +--- +uid: uno.publishing.desktop.linux +--- + +# Publishing Your App for Linux + +## Snap Packages + +We support creating .snap packages on **Ubuntu 20.04** or later. + +### Requirements + +The following must be installed and configured: + +```bash +sudo apt-get install -y snapd +sudo snap install core22 +sudo snap install multipass +sudo snap install lxd +sudo snap install snapcraft +lxd init --minimal +sudo usermod --append --groups lxd $USER # In order for the current user to use LXD +``` + +> [!NOTE] +> In the above script, replace `core22` with `core20` if building on Ubuntu 20.04, or `core24` if building on Ubuntu 24.04. +> [!NOTE] +> Docker may interfere with Lxd causing network connectivity issues, for solutions see: https://documentation.ubuntu.com/lxd/en/stable-5.0/howto/network_bridge_firewalld/#prevent-connectivity-issues-with-lxd-and-docker + +### Generate a Snap file + +To generate a snap file, run the following: + +```shell +dotnet publish -f net8.0-desktop -p:SelfContained=true -p:PackageFormat=snap +``` + +The generated snap file is located in the `bin/Release/netX.0-desktop/linux-[x64|arm64]/publish` folder. + +Uno Platform generates snap manifests in classic confinement mode and a `.desktop` file by default. + +If you wish to customize your snap manifest, you will need to pass the following MSBuild properties: + +- `SnapManifest` +- `DesktopFile` + +The `.desktop` filename MUST conform to the [Desktop File](https://specifications.freedesktop.org/desktop-entry-spec/latest) spec. + +If you wish, you can generate a default snap manifest and desktop file by running the command above, then tweak them. + +> [!NOTE] +> .NET 9 publishing and cross-publishing are not supported as of Uno 5.5, we will support .NET 9 publishing soon. + +### Publish your Snap Package + +You can install your app on your machine using the following: + +```bash +sudo snap install MyApp_1.0_amd64.snap --dangerous --classic +``` + +You can also publish your app to the [Snap store](https://snapcraft.io/store). + +## Limitations + +- NativeAOT is not yet supported +- R2R is not yet supported +- Single file publish is not yet supported + +> [!NOTE] +> Publishing is a [work in progress](https://github.com/unoplatform/uno/issues/16440) + +## Links + +- [Snapcraft.yaml schema](https://snapcraft.io/docs/snapcraft-yaml-schema) +- [Desktop Entry Specification](https://specifications.freedesktop.org/desktop-entry-spec/latest) diff --git a/doc/articles/uno-publishing-desktop.md b/doc/articles/uno-publishing-desktop.md index c55ef9b25c31..85be4eebc075 100644 --- a/doc/articles/uno-publishing-desktop.md +++ b/doc/articles/uno-publishing-desktop.md @@ -136,93 +136,3 @@ Depending on your deployment settings, you can run the `Setup.exe` file to insta > [!IMPORTANT] > At this time, publishing with the Visual Studio Publishing Wizard is not supported for > multi-targeted projects. Using the command line above is required. - -### macOS App Bundles - -We now support generating `.app` bundles on macOS machines. From the CLI run: - -```shell -dotnet publish -f net8.0-desktop -p:PackageFormat=app -``` - -You can also do a self-contained publish with: - -```shell -dotnet publish -f net8.0-desktop -r {{RID}} -p:SelfContained=true -p:PackageFormat=app -``` - -Where `{{RID}}` is either `osx-x64` or `osx-arm64`. - -> [!NOTE] -> Code signing is planned but not supported yet. - -### Snap Packages - -We support creating .snap packages on **Ubuntu 20.04** or later. - -#### Requirements - -The following must be installed and configured: - -```bash -sudo apt-get install -y snapd -sudo snap install core22 -sudo snap install multipass -sudo snap install lxd -sudo snap install snapcraft -lxd init --minimal -sudo usermod --append --groups lxd $USER # In order for the current user to use LXD -``` - -> [!NOTE] -> In the above script, replace `core22` with `core20` if building on Ubuntu 20.04, or `core24` if building on Ubuntu 24.04. -> [!NOTE] -> Docker may interfere with Lxd causing network connectivity issues, for solutions see: https://documentation.ubuntu.com/lxd/en/stable-5.0/howto/network_bridge_firewalld/#prevent-connectivity-issues-with-lxd-and-docker - -#### Generate a Snap file - -To generate a snap file, run the following: - -```shell -dotnet publish -f net8.0-desktop -p:SelfContained=true -p:PackageFormat=snap -``` - -The generated snap file is located in the `bin/Release/netX.0-desktop/linux-[x64|arm64]/publish` folder. - -Uno Platform generates snap manifests in classic confinement mode and a `.desktop` file by default. - -If you wish to customize your snap manifest, you will need to pass the following MSBuild properties: - -- `SnapManifest` -- `DesktopFile` - -The `.desktop` filename MUST conform to the [Desktop File](https://specifications.freedesktop.org/desktop-entry-spec/latest) spec. - -If you wish, you can generate a default snap manifest and desktop file by running the command above, then tweak them. - -> [!NOTE] -> .NET 9 publishing and cross-publishing are not supported as of Uno 5.5, we will support .NET 9 publishing soon. - -#### Publish your Snap Package - -You can install your app on your machine using the following: - -```bash -sudo snap install MyApp_1.0_amd64.snap --dangerous --classic -``` - -You can also publish your app to the [Snap store](https://snapcraft.io/store). - -## Limitations - -- NativeAOT is not yet supported -- R2R is not yet supported -- Single file publish is not yet supported - -> [!NOTE] -> Publishing is a [work in progress](https://github.com/unoplatform/uno/issues/16440) - -## Links - -- [Snapcraft.yaml schema](https://snapcraft.io/docs/snapcraft-yaml-schema) -- [Desktop Entry Specification](https://specifications.freedesktop.org/desktop-entry-spec/latest)