Bit.Bswup 9.3.0

There is a newer prerelease version of this package available.
See the version list below for details.
dotnet add package Bit.Bswup --version 9.3.0                
NuGet\Install-Package Bit.Bswup -Version 9.3.0                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Bit.Bswup" Version="9.3.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Bit.Bswup --version 9.3.0                
#r "nuget: Bit.Bswup, 9.3.0"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install Bit.Bswup as a Cake Addin
#addin nuget:?package=Bit.Bswup&version=9.3.0

// Install Bit.Bswup as a Cake Tool
#tool nuget:?package=Bit.Bswup&version=9.3.0                

bit Blazor Service-Worker Update Progress (bit Bswup)

To use the bit Bswup, please follow these steps:

  1. Install the Bit.Bswup nuget package:
dotnet add package Bit.Bswup
  1. Enable static file caching. You can follow the below code in the Startup.cs file:
app.UseStaticFiles(new StaticFileOptions
{
    OnPrepareResponse = ctx =>
    {
        if (env.IsDevelopment() is false)
        {
            // https://bitplatform.dev/templates/cache-mechanism
            ctx.Context.Response.GetTypedHeaders().CacheControl = new()
            {
                MaxAge = TimeSpan.FromDays(7),
                Public = true
            };
        }
    }
});
  1. In the default document (index.html, _Host.cshtml, or _Layout.cshtml), add autostart="false" to the script tag for the Blazor script:
<script src="_framework/blazor.webassembly.js" autostart="false"></script>
  1. Also In the default document (index.html, _Host.cshtml, or _Layout.cshtml), add the bit-bswup.js script tag after the Blazor script tag with needed options:
<script src="_content/Bit.Bswup/bit-bswup.js"
        scope="/"
        log="verbose"
        sw="service-worker.js"
        handler="bitBswupHandler"></script>
  • scope: The scope of the service-worker (read more).
  • log: The log level of the Bswup logger. available options are: info, verbose, debug, and error. (not implemented yet)
  • sw: The file path of the service-worker file.
  • handler: The name of the handler function for the service-worker events.

You can remove any of these attributes, and use the default values mentioned above.

  1. Add a handler function like the below code to handle multiple events of the Bswup, or you can follow the full sample code which is provided in the Demo projects of this repo.
const appEl = document.getElementById('app');
const bswupEl = document.getElementById('bit-bswup');
const progressBar = document.getElementById('bit-bswup-progress-bar');
const reloadButton = document.getElementById('bit-bswup-reload');

function bitBswupHandler(type, data) {
    switch (type)
    {
        case BswupMessage.updateFound: return console.log('an update found.');

        case BswupMessage.stateChanged: return console.log('state has changed to:', data.currentTarget.state);

        case BswupMessage.activate: return console.log('new version activated:', data.version);

        case BswupMessage.downloadStarted: 
            appEl.style.display = 'none';
            bswupEl.style.display = 'block';
            return console.log('downloading assets started:', data?.version);

        case BswupMessage.downloadProgress:
            progressBar.style.width = `${percent}%`;
            return console.log('asset downloaded:', data);

        case BswupMessage.downloadFinished:
            if (data.firstInstall) {
                data.reload().then(() => {
                    appEl.style.display = 'block';
                    bswupEl.style.display = 'none';
                });
            } else {
                reloadButton.style.display = 'block';
                reloadButton.onclick = data.reload;
            }
            return console.log('downloading assets finished.');

        case BswupMessage.updateReady:
            reloadButton.style.display = 'block';
            reloadButton.onclick = data.reload;
            return console.log('new update ready.');
    }
}
  1. Configure additional settings in the service-worker file like the following code:
self.assetsInclude = [/\data.db$/];
self.assetsExclude = [/\.scp\.css$/, /weather\.json$/];
self.defaultUrl = '/';
self.prohibitedUrls = [/\/admin\//];
self.serverHandledUrls = [/\/api\//];
self.serverRenderedUrls = [/\/privacy$/];
self.externalAssets = [
    {
        "url": "/"
    },
    {
        "url": "https://www.googletagmanager.com/gtag/js?id=G-G123456789"
    }
];
self.assetsUrl = '/service-worker-assets.js';
self.noPrerenderQuery = 'no-prerender=true';

self.caseInsensitiveUrl = true;
self.ignoreDefaultInclude = true;
self.ignoreDefaultExclude = true;
self.isPassive = true;
self.disablePassiveFirstBoot = true;
self.enableIntegrityCheck = true;
self.enableDiagnostics = true;
self.enableFetchDiagnostics = true;

self.importScripts('_content/Bit.Bswup/bit-bswup.sw.js');

The most important line here is the last line which is the only mandatory config in this file that imports the Bswup service-worker file:

self.importScripts('_content/Bit.Bswup/bit-bswup.sw.js');

The other settings are:

  • assetsInclude: The list of file names from the assets list to include when the Bswup tries to store them in the cache storage (regex supported).
  • assetsExclude: The list of file names from the assets list to exclude when the Bswup tries to store them in the cache storage (regex supported).
  • externalAssets: The list of external assets to cache that are not included in the auto-generated assets file. For example, if you're not using index.html (like _host.cshtml), then you should add { "url": "/" }.
  • defaultUrl: The default page URL. Use / when using _Host.cshtml.
  • assetsUrl: The file path of the service-worker assets file generated at compile time (the default file name is service-worker-assets.js).
  • prohibitedUrls: The list of file names that should not be accessed (regex supported).
  • caseInsensitiveUrl: Enables the case insensitivity in the URL checking of the cache process.
  • serverHandledUrls: The list of URLs that do not enter the service-worker offline process and will be handled only by server (regex supported). such as /api, /swagger, ...
  • serverRenderedUrls: The list of URLs that should be rendered by the server and not client while navigating (regex supported). such as /about.html, /privacy, ...
  • noPrerenderQuery: The query string attached to the default document request to disable the prerendering from the server so an unwanted prerendered result not be cached.
  • ignoreDefaultInclude: Ignores the default asset includes array which is provided by the Bswup itself which is like this:
    [/\.dll$/, /\.pdb$/, /\.wasm/, /\.html/, /\.js$/, /\.json$/, /\.css$/, /\.woff$/, /\.png$/, /\.jpe?g$/, /\.gif$/, /\.ico$/, /\.blat$/, /\.dat$/, /\.svg$/, /\.woff2$/, /\.ttf$/, /\.webp$/]
    
  • ignoreDefaultExclude: Ignores the default asset excludes array which is provided by the Bswup itself which is like this:
    [/^_content\/Bit\.Bswup\/bit-bswup\.sw\.js$/, /^service-worker\.js$/]
    
  • isPassive: Enables the Bswup's passive mode. In this mode, the assets won't be cached in advance but rather upon initial request.
  • disablePassiveFirstBoot: Disables downloading the Blazor's boot files in first time of Passive mode.
  • enableIntegrityCheck: Enables the default integrity check available in browsers by setting the integrity attribute of the request object created in the service-worker to fetch the assets.
  • errorTolerance: Determines how the Bswup should handle the errors while downloading assets. Possible values are: strict, lax, config.
  • enableDiagnostics: Enables diagnostics by pushing service-worker logs to the browser console.
  • enableFetchDiagnostics: Enables fetch event diagnostics by pushing service-worker fetch event logs to the browser console.
  • disableHashlessAssetsUpdate: Disables the update of the hash-less assets. By default, the Bswup tries to automatically update all of the hash-less assets (e.g. the external assets) every time an update found for the app.
Product Compatible and additional computed target framework versions.
.NET net8.0 is compatible.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 is compatible.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories (2)

Showing the top 2 popular GitHub repositories that depend on Bit.Bswup:

Repository Stars
bitfoundation/bitplatform
Build all of your apps using what you already know and love ❤️
functionland/fx-files
You want to literally own your files? This is something won't happen on traditional cloud services in a lifetime. And this is something is going to happen in a glance with "Fx Files" app from now on. It is a file manager which stores everything on Fula blockchain network of Bloxes.
Version Downloads Last updated
9.3.1-pre-05 123 1/26/2025
9.3.1-pre-04 219 1/23/2025
9.3.1-pre-03 148 1/19/2025
9.3.1-pre-02 67 1/18/2025
9.3.1-pre-01 135 1/14/2025
9.3.0 261 1/11/2025
9.3.0-pre-01 59 1/11/2025
9.2.1 444 1/5/2025
9.2.1-pre-02 185 1/4/2025
9.2.1-pre-01 189 1/3/2025
9.2.0 165 1/1/2025
9.2.0-pre-04 79 1/1/2025
9.2.0-pre-03 105 12/31/2024
9.2.0-pre-02 152 12/31/2024
9.2.0-pre-01 87 12/30/2024
9.1.2 516 12/24/2024
9.1.2-pre-01 95 12/23/2024
9.1.1 455 12/15/2024
9.1.1-pre-01 89 12/15/2024
9.1.0 136 12/14/2024
9.1.0-pre-13 99 12/13/2024
9.1.0-pre-12 84 12/13/2024
9.1.0-pre-11 83 12/13/2024
9.1.0-pre-10 178 12/10/2024
9.1.0-pre-09 162 12/6/2024
9.1.0-pre-08 243 12/2/2024
9.1.0-pre-07 76 12/2/2024
9.1.0-pre-06 70 12/2/2024
9.1.0-pre-05 148 12/1/2024
9.1.0-pre-04 111 11/29/2024
9.1.0-pre-03 325 11/25/2024
9.1.0-pre-02 162 11/24/2024
9.1.0-pre-01 95 11/23/2024
9.0.1 475 11/20/2024
9.0.0 213 11/18/2024
9.0.0-pre-02 82 11/18/2024
9.0.0-pre-01 209 11/15/2024
8.12.0 459 11/12/2024
8.12.0-pre-15 134 11/11/2024
8.12.0-pre-14 115 11/11/2024
8.12.0-pre-13 137 11/11/2024
8.12.0-pre-12 120 11/10/2024
8.12.0-pre-11 122 11/9/2024
8.12.0-pre-10 249 11/5/2024
8.12.0-pre-09 96 11/5/2024
8.12.0-pre-08 254 11/1/2024
8.12.0-pre-07 285 10/27/2024
8.12.0-pre-06 188 10/24/2024
8.12.0-pre-05 137 10/21/2024
8.12.0-pre-04 125 10/20/2024
8.12.0-pre-03 561 10/6/2024
8.12.0-pre-02 195 10/2/2024
8.12.0-pre-01 106 9/29/2024
8.11.1-pre-04 147 9/27/2024
8.11.1-pre-03 104 9/26/2024
8.11.1-pre-02 259 9/22/2024
8.11.1-pre-01 191 9/19/2024
8.11.0 449 9/16/2024
8.11.0-pre-09 119 9/15/2024
8.11.0-pre-08 143 9/13/2024
8.11.0-pre-07 162 9/10/2024
8.11.0-pre-06 240 9/4/2024
8.11.0-pre-05 122 9/3/2024
8.11.0-pre-04 329 8/22/2024
8.11.0-pre-03 160 8/21/2024
8.11.0-pre-02 162 8/19/2024
8.11.0-pre-01 182 8/16/2024
8.10.0 651 8/8/2024
8.10.0-pre-05 171 8/4/2024
8.10.0-pre-04 92 8/3/2024
8.10.0-pre-03 744 6/26/2024
8.10.0-pre-02 122 6/26/2024
8.10.0-pre-01 111 6/25/2024
8.9.0 1,133 6/9/2024
8.9.0-pre-04 117 6/9/2024
8.9.0-pre-03 166 6/6/2024
8.9.0-pre-02 212 5/31/2024
8.9.0-pre-01 117 5/28/2024
8.8.2-pre-05 139 5/27/2024
8.8.2-pre-04 119 5/26/2024
8.8.2-pre-03 130 5/23/2024
8.8.2-pre-02 289 5/9/2024
8.8.2-pre-01 177 5/1/2024
8.8.1 2,990 4/13/2024
8.8.1-pre-02 94 4/12/2024
8.8.1-pre-01 119 4/12/2024
8.8.0 535 4/1/2024
8.8.0-pre-04 141 3/29/2024
8.8.0-pre-03 260 3/16/2024
8.8.0-pre-02 182 3/10/2024
8.8.0-pre-01 285 2/27/2024
8.7.6 1,755 2/23/2024
8.7.6-pre-08 171 2/23/2024
8.7.6-pre-07 109 2/21/2024
8.7.6-pre-06 116 2/21/2024
8.7.6-pre-05 133 2/18/2024
8.7.6-pre-04 152 2/14/2024
8.7.6-pre-03 107 2/14/2024
8.7.6-pre-02 102 2/14/2024
8.7.6-pre-01 97 2/12/2024
8.7.5 197 2/9/2024
8.7.5-pre-04 127 2/3/2024
8.7.5-pre-03 139 1/29/2024
8.7.5-pre-02 135 1/25/2024
8.7.5-pre-01 104 1/24/2024
8.7.4 368 1/23/2024
8.7.3-pre-02 117 1/22/2024
8.7.3-pre-01 198 1/20/2024
8.7.2 209 1/17/2024
8.7.2-pre-02 102 1/17/2024
8.7.2-pre-01 201 1/11/2024
8.7.1 313 1/9/2024
8.7.0 210 1/8/2024
8.7.0-pre-05 151 1/7/2024
8.7.0-pre-04 171 1/5/2024
8.7.0-pre-03 124 1/4/2024
8.7.0-pre-02 169 12/31/2023
8.7.0-pre-01 118 12/31/2023
8.6.0 209 12/31/2023
8.6.0-pre-03 177 12/25/2023
8.6.0-pre-02 111 12/25/2023
8.6.0-pre-01 199 12/21/2023
8.5.0 254 12/20/2023
8.5.0-pre-02 175 12/16/2023
8.5.0-pre-01 119 12/15/2023
8.4.0 182 12/14/2023
8.4.0-pre-01 123 12/13/2023
8.3.0 164 12/12/2023
8.3.0-pre-03 133 12/11/2023
8.3.0-pre-02 144 12/11/2023
8.3.0-pre-01 133 12/11/2023
8.2.0 345 12/2/2023
8.2.0-pre-05 136 12/2/2023
8.2.0-pre-04 188 12/1/2023
8.2.0-pre-03 147 11/30/2023
8.2.0-pre-02 171 11/29/2023
8.2.0-pre-01 280 11/25/2023
8.1.0 315 11/22/2023
8.1.0-pre-03 134 11/22/2023
8.1.0-pre-02 166 11/20/2023
8.1.0-pre-01 191 11/17/2023
8.0.1 224 11/14/2023
8.0.0-pre-01 142 11/14/2023
7.3.0 138 11/14/2023
7.3.0-pre-01 85 11/14/2023
7.2.0 111 11/14/2023
7.2.0-pre-02 92 11/14/2023
7.2.0-pre-01 144 11/12/2023
7.1.0 191 11/8/2023
7.1.0-pre-05 123 11/7/2023
7.1.0-pre-04 304 11/4/2023
7.1.0-pre-03 377 10/27/2023
7.1.0-pre-02 267 10/23/2023
7.1.0-pre-01 303 10/17/2023
7.0.0 293 10/15/2023
7.0.0-pre-02 88 10/15/2023
7.0.0-pre-01 201 10/13/2023
6.1.0 236 10/13/2023
6.1.0-pre-03 86 10/13/2023
6.1.0-pre-02 101 10/12/2023
6.1.0-pre-01 143 10/11/2023
6.0.0 184 10/9/2023
6.0.0-pre-05 101 10/8/2023
6.0.0-pre-04 112 10/6/2023
6.0.0-pre-03 136 10/2/2023
6.0.0-pre-02 155 9/29/2023
6.0.0-pre-01 114 9/27/2023
5.6.1 407 9/20/2023
5.6.1-pre-01 117 9/20/2023
5.6.0 174 9/20/2023
5.6.0-pre-03 112 9/20/2023
5.6.0-pre-02 218 9/18/2023
5.6.0-pre-01 326 9/14/2023
5.5.0 592 9/2/2023
5.5.0-pre-08 177 9/2/2023
5.5.0-pre-07 183 8/30/2023
5.5.0-pre-06 149 8/29/2023
5.5.0-pre-05 172 8/28/2023
5.5.0-pre-04 142 8/28/2023
5.5.0-pre-03 188 8/27/2023
5.5.0-pre-02 172 8/26/2023
5.5.0-pre-01 162 8/24/2023
5.4.0 281 8/20/2023
5.4.0-pre-05 155 8/20/2023
5.4.0-pre-04 189 8/19/2023
5.4.0-pre-03 154 8/19/2023
5.4.0-pre-02 155 8/19/2023
5.4.0-pre-01 219 8/15/2023
5.3.0 329 8/10/2023
5.3.0-pre-07 152 8/9/2023
5.3.0-pre-06 179 8/8/2023
5.3.0-pre-05 205 8/7/2023
5.3.0-pre-04 200 8/6/2023
5.3.0-pre-03 232 8/1/2023
5.3.0-pre-02 135 8/1/2023
5.3.0-pre-01 158 7/31/2023
5.2.0 288 7/28/2023
5.2.0-pre-05 167 7/27/2023
5.2.0-pre-03 562 7/24/2023
5.2.0-pre-02 171 7/24/2023
5.2.0-pre-01 255 7/10/2023
5.1.0 456 7/5/2023
5.1.0-pre-16 156 7/4/2023
5.1.0-pre-15 198 7/3/2023
5.1.0-pre-14 165 7/3/2023
5.1.0-pre-13 146 7/3/2023
5.1.0-pre-12 164 7/2/2023
5.1.0-pre-11 150 7/2/2023
5.1.0-pre-10 139 7/2/2023
5.1.0-pre-09 224 6/29/2023
5.1.0-pre-08 180 6/27/2023
5.1.0-pre-07 146 6/25/2023
5.1.0-pre-06 158 6/24/2023
5.1.0-pre-04 170 6/24/2023
5.1.0-pre-03 198 6/22/2023
5.1.0-pre-02 232 6/17/2023
5.1.0-pre-01 160 6/16/2023
5.0.0 384 5/29/2023
5.0.0-pre-02 138 5/29/2023
5.0.0-pre-01 168 5/25/2023
4.9.11-pre-02 135 5/25/2023
4.9.11-pre-01 144 5/25/2023
4.9.10 258 5/25/2023
4.9.10-pre-07 134 5/25/2023
4.9.10-pre-06 189 5/16/2023
4.9.10-pre-05 135 5/15/2023
4.9.10-pre-04 186 5/6/2023
4.9.10-pre-03 175 5/2/2023
4.9.10-pre-01 163 4/26/2023
4.9.9 402 4/10/2023
4.9.9-pre-03 151 4/9/2023
4.9.9-pre-02 192 3/29/2023
4.9.9-pre-01 187 3/29/2023
4.9.8-pre-02 257 3/21/2023
4.9.8-pre-01 179 3/20/2023
4.9.7-pre-01 253 3/6/2023
4.9.6 610 2/25/2023
4.9.6-pre-05 224 2/23/2023
4.9.6-pre-04 162 2/23/2023
4.9.6-pre-03 222 2/20/2023
4.9.6-pre-02 188 2/15/2023
4.9.5 593 2/8/2023
4.9.5-pre-03 149 2/8/2023
4.9.5-pre-02 152 2/8/2023
4.9.5-pre-01 155 2/7/2023
4.9.4 435 1/31/2023
4.9.4-pre-02 175 1/31/2023
4.9.4-pre-01 184 1/27/2023
4.9.3-pre-04 211 1/22/2023
4.9.3-pre-03 192 1/20/2023
4.9.3-pre-02 197 1/19/2023
4.9.2-pre-01 222 1/9/2023
4.9.1-pre-02 266 12/26/2022
4.9.1-pre-01 183 12/18/2022
4.9.0-pre-02 250 11/27/2022
4.9.0-pre-01 174 11/22/2022
4.8.0 543 11/15/2022
4.8.0-pre-02 140 11/14/2022
4.8.0-pre-01 175 11/11/2022
4.7.0 378 10/31/2022
4.7.0-pre-04 123 10/31/2022
4.7.0-pre-03 106 10/31/2022
4.7.0-pre-02 166 10/29/2022
4.7.0-pre-01 109 10/27/2022
4.6.0-pre-01 110 10/27/2022
4.5.0-pre-01 207 10/20/2022
4.4.1-pre-01 145 10/20/2022
4.4.0-pre-01 118 10/15/2022
4.3.2-pre-04 110 10/7/2022
4.3.2-pre-03 91 10/6/2022
4.3.2-pre-01 118 9/29/2022
4.3.1 721 9/21/2022
4.3.0 125 9/21/2022
4.2.0-pre-07 135 9/19/2022
4.2.0-pre-05 165 9/18/2022
4.2.0-pre-04 158 9/18/2022
4.2.0-pre-02 243 9/14/2022
4.2.0-pre-01 116 9/12/2022
4.1.0 366 9/8/2022
4.1.0-pre-01 141 9/8/2022
4.0.0 235 9/1/2022
3.1.0-pre-07 110 9/1/2022
3.1.0-pre-06 116 8/30/2022
3.1.0-pre-05 119 8/29/2022
3.1.0-pre-04 131 8/28/2022
3.1.0-pre-03 116 8/27/2022
3.1.0-pre-02 142 8/25/2022
3.1.0-pre-01 142 8/23/2022
3.0.0 257 8/15/2022
3.0.0-pre-09 127 8/15/2022
3.0.0-pre-08 119 8/15/2022
3.0.0-pre-07 142 8/15/2022
3.0.0-pre-06 166 8/14/2022
3.0.0-pre-05 179 8/14/2022
3.0.0-pre-04 282 8/9/2022
3.0.0-pre-03 199 8/8/2022
3.0.0-pre-02 215 8/7/2022
3.0.0-pre-01 348 7/29/2022
2.0.0 600 7/25/2022
2.0.0-pre-14 206 7/24/2022
2.0.0-pre-12 226 7/21/2022
2.0.0-pre-11 170 7/21/2022
2.0.0-pre-10 163 7/20/2022
2.0.0-pre-09 282 7/20/2022
2.0.0-pre-08 309 7/19/2022
2.0.0-pre-07 321 7/19/2022
2.0.0-pre-06 214 7/18/2022
2.0.0-pre-05 300 7/17/2022
2.0.0-pre-04 276 7/14/2022
2.0.0-pre-03 268 7/13/2022
2.0.0-pre-02 258 7/12/2022
2.0.0-pre-01 373 7/8/2022
2.0.0-pre-00 273 7/4/2022
1.0.2 766 7/4/2022
1.0.0 521 7/4/2022