mirror of https://github.com/Chocobozzz/PeerTube
				
				
				
			Fix service worker
							parent
							
								
									83befebe52
								
							
						
					
					
						commit
						1d22d2514f
					
				|  | @ -1,7 +1,9 @@ | |||
| import 'focus-visible' | ||||
| import { environment } from 'src/environments/environment' | ||||
| import { APP_BASE_HREF, registerLocaleData } from '@angular/common' | ||||
| import { NgModule } from '@angular/core' | ||||
| import { BrowserModule } from '@angular/platform-browser' | ||||
| import { ServiceWorkerModule } from '@angular/service-worker' | ||||
| import { ServerService } from '@app/core' | ||||
| import localeOc from '@app/helpers/locales/oc' | ||||
| import { MetaLoader, MetaModule, MetaStaticLoader, PageTitlePositioning } from '@ngx-meta/core' | ||||
|  | @ -11,7 +13,7 @@ import { CoreModule } from './core' | |||
| import { EmptyComponent } from './empty.component' | ||||
| import { HeaderComponent, SearchTypeaheadComponent, SuggestionComponent } from './header' | ||||
| import { HighlightPipe } from './header/highlight.pipe' | ||||
| import { NotificationComponent, LanguageChooserComponent, MenuComponent } from './menu' | ||||
| import { LanguageChooserComponent, MenuComponent, NotificationComponent } from './menu' | ||||
| import { ConfirmComponent } from './modal/confirm.component' | ||||
| import { CustomModalComponent } from './modal/custom-modal.component' | ||||
| import { InstanceConfigWarningModalComponent } from './modal/instance-config-warning-modal.component' | ||||
|  | @ -49,6 +51,7 @@ registerLocaleData(localeOc, 'oc') | |||
| 
 | ||||
|   imports: [ | ||||
|     BrowserModule, | ||||
|     ServiceWorkerModule.register('ngsw-worker.js', { enabled: environment.production }), | ||||
| 
 | ||||
|     CoreModule, | ||||
|     SharedMainModule, | ||||
|  |  | |||
|  | @ -11,11 +11,6 @@ if (environment.production) { | |||
| const bootstrap = () => platformBrowserDynamic() | ||||
|   .bootstrapModule(AppModule) | ||||
|   .then(bootstrapModule => { | ||||
|     if ('serviceWorker' in navigator && environment.production) { | ||||
|       navigator.serviceWorker.register('/ngsw-worker.js') | ||||
|         .catch(err => console.error('Cannot register service worker.', err)) | ||||
|     } | ||||
| 
 | ||||
|     if (!environment.production) { | ||||
|       const applicationRef = bootstrapModule.injector.get(ApplicationRef) | ||||
|       const componentRef = applicationRef.components[0] | ||||
|  |  | |||
|  | @ -1,4 +1,7 @@ | |||
| { | ||||
|   "name": "PeerTube", | ||||
|   "short_name": "PeerTube", | ||||
|   "start_url": "/", | ||||
|   "background_color": "#fff", | ||||
|   "theme_color": "#fff", | ||||
|   "description": "A federated video streaming platform using P2P", | ||||
|  | @ -40,8 +43,5 @@ | |||
|       "sizes": "512x512", | ||||
|       "type": "image/png" | ||||
|     } | ||||
|   ], | ||||
|   "name": "PeerTube", | ||||
|   "short_name": "PeerTube", | ||||
|   "start_url": "/" | ||||
|   ] | ||||
| } | ||||
|  |  | |||
|  | @ -1,4 +1,5 @@ | |||
| { | ||||
|   "$schema": "../node_modules/@angular/service-worker/config/schema.json", | ||||
|   "index": "/index.html", | ||||
|   "assetGroups": [ | ||||
|     { | ||||
|  |  | |||
|  | @ -69,8 +69,7 @@ else | |||
|     npm run ng build -- --localize=false --output-path "dist/$defaultLanguage/" --deploy-url "/client/$defaultLanguage/" --prod --stats-json $additionalParams | ||||
| fi | ||||
| 
 | ||||
| mv "./dist/$defaultLanguage/manifest.webmanifest" "./dist/manifest.webmanifest" | ||||
| mv "./dist/$defaultLanguage/ngsw-worker.js" "./dist/" | ||||
| cp "./dist/$defaultLanguage/manifest.webmanifest" "./dist/manifest.webmanifest" | ||||
| 
 | ||||
| cd ../ && npm run build:embed && cd client/ | ||||
| 
 | ||||
|  |  | |||
|  | @ -1,9 +1,10 @@ | |||
| import * as express from 'express' | ||||
| import { constants, promises as fs } from 'fs' | ||||
| import { readFile } from 'fs-extra' | ||||
| import { join } from 'path' | ||||
| import { CONFIG } from '@server/initializers/config' | ||||
| import { buildFileLocale, getCompleteLocale, is18nLocale, LOCALE_FILES } from '@shared/core-utils/i18n' | ||||
| import { HttpStatusCode } from '@shared/core-utils' | ||||
| import { buildFileLocale, getCompleteLocale, I18N_LOCALES, is18nLocale, LOCALE_FILES } from '@shared/core-utils/i18n' | ||||
| import { root } from '../helpers/core-utils' | ||||
| import { STATIC_MAX_AGE } from '../initializers/constants' | ||||
| import { ClientHtml, sendHTML, serveIndexHTML } from '../lib/client-html' | ||||
|  | @ -46,22 +47,8 @@ const testEmbedController = (req: express.Request, res: express.Response) => res | |||
| clientsRouter.use('/videos/test-embed', testEmbedController) | ||||
| clientsRouter.use('/video-playlists/test-embed', testEmbedController) | ||||
| 
 | ||||
| // Static HTML/CSS/JS client files
 | ||||
| const staticClientFiles = [ | ||||
|   'ngsw-worker.js', | ||||
|   'ngsw.json' | ||||
| ] | ||||
| 
 | ||||
| for (const staticClientFile of staticClientFiles) { | ||||
|   const path = join(root(), 'client', 'dist', staticClientFile) | ||||
| 
 | ||||
|   clientsRouter.get(`/${staticClientFile}`, (req: express.Request, res: express.Response) => { | ||||
|     res.sendFile(path, { maxAge: STATIC_MAX_AGE.SERVER }) | ||||
|   }) | ||||
| } | ||||
| 
 | ||||
| // Dynamic PWA manifest
 | ||||
| clientsRouter.get('/manifest.webmanifest', asyncMiddleware(generateManifest)) | ||||
| clientsRouter.get(/\/client\/[^/]+\/manifest.webmanifest/, asyncMiddleware(generateManifest)) | ||||
| 
 | ||||
| // Static client overrides
 | ||||
| // Must be consistent with static client overrides redirections in /support/nginx/peertube
 | ||||
|  | @ -149,7 +136,7 @@ async function generateVideoChannelHtmlPage (req: express.Request, res: express. | |||
| 
 | ||||
| async function generateManifest (req: express.Request, res: express.Response) { | ||||
|   const manifestPhysicalPath = join(root(), 'client', 'dist', 'manifest.webmanifest') | ||||
|   const manifestJson = await fs.readFile(manifestPhysicalPath, 'utf8') | ||||
|   const manifestJson = await readFile(manifestPhysicalPath, 'utf8') | ||||
|   const manifest = JSON.parse(manifestJson) | ||||
| 
 | ||||
|   manifest.name = CONFIG.INSTANCE.NAME | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	 Chocobozzz
						Chocobozzz