mirror of
https://github.com/DSpace/dspace-angular.git
synced 2025-10-07 01:54:15 +00:00
Fixed AoT Build
This commit is contained in:
4
src/main.server.aot.ts
Normal file
4
src/main.server.aot.ts
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
import { startServer } from './server';
|
||||||
|
import { ServerAppModuleNgFactory } from './modules/app/server-app.module.ngfactory';
|
||||||
|
|
||||||
|
startServer(ServerAppModuleNgFactory);
|
@@ -1,134 +1,4 @@
|
|||||||
import 'zone.js/dist/zone-node';
|
import { startServer } from './server';
|
||||||
import 'reflect-metadata';
|
|
||||||
import 'rxjs/Rx';
|
|
||||||
|
|
||||||
import * as fs from 'fs';
|
|
||||||
import * as pem from 'pem';
|
|
||||||
import * as https from 'https';
|
|
||||||
import * as morgan from 'morgan';
|
|
||||||
import * as express from 'express';
|
|
||||||
import * as bodyParser from 'body-parser';
|
|
||||||
import * as compression from 'compression';
|
|
||||||
import * as cookieParser from 'cookie-parser';
|
|
||||||
|
|
||||||
import { enableProdMode } from '@angular/core';
|
|
||||||
|
|
||||||
import { ngExpressEngine } from '@nguniversal/express-engine';
|
|
||||||
|
|
||||||
import { ServerAppModule } from './modules/app/server-app.module';
|
import { ServerAppModule } from './modules/app/server-app.module';
|
||||||
|
|
||||||
import { ROUTES } from './routes';
|
startServer(ServerAppModule);
|
||||||
import { ENV_CONFIG } from './config';
|
|
||||||
|
|
||||||
const app = express();
|
|
||||||
|
|
||||||
const port = ENV_CONFIG.ui.port ? ENV_CONFIG.ui.port : 80;
|
|
||||||
|
|
||||||
if (ENV_CONFIG.production) {
|
|
||||||
enableProdMode();
|
|
||||||
app.use(compression());
|
|
||||||
}
|
|
||||||
|
|
||||||
app.use(morgan('dev'));
|
|
||||||
|
|
||||||
app.use(cookieParser());
|
|
||||||
app.use(bodyParser.json());
|
|
||||||
|
|
||||||
app.engine('html', ngExpressEngine({
|
|
||||||
bootstrap: ServerAppModule
|
|
||||||
}));
|
|
||||||
|
|
||||||
app.set('view engine', 'html');
|
|
||||||
app.set('views', 'src');
|
|
||||||
|
|
||||||
function cacheControl(req, res, next) {
|
|
||||||
// instruct browser to revalidate
|
|
||||||
res.header('Cache-Control', ENV_CONFIG.cache.control || 'max-age=60');
|
|
||||||
next();
|
|
||||||
}
|
|
||||||
|
|
||||||
app.use('/', cacheControl, express.static('dist', { index: false }));
|
|
||||||
|
|
||||||
// TODO: either remove or update mock backend
|
|
||||||
// app.get('/data.json', serverApi);
|
|
||||||
// app.use('/api', createMockApi());
|
|
||||||
|
|
||||||
function ngApp(req, res) {
|
|
||||||
|
|
||||||
function onHandleError(parentZoneDelegate, currentZone, targetZone, error) {
|
|
||||||
console.warn('Error in SSR, serving for direct CSR');
|
|
||||||
res.sendFile('index.csr.html', { root: './src' });
|
|
||||||
}
|
|
||||||
|
|
||||||
if (ENV_CONFIG.universal.preboot) {
|
|
||||||
Zone.current.fork({ name: 'CSR fallback', onHandleError }).run(() => {
|
|
||||||
res.render('../dist/index', {
|
|
||||||
req,
|
|
||||||
res,
|
|
||||||
preboot: ENV_CONFIG.universal.preboot,
|
|
||||||
async: ENV_CONFIG.universal.async,
|
|
||||||
time: ENV_CONFIG.universal.time,
|
|
||||||
baseUrl: ENV_CONFIG.ui.nameSpace,
|
|
||||||
originUrl: ENV_CONFIG.ui.baseUrl,
|
|
||||||
requestUrl: req.originalUrl
|
|
||||||
});
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
console.log('Universal off, serving for direct CSR');
|
|
||||||
res.sendFile('index.csr.html', { root: './src' });
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
ROUTES.forEach((route: string) => {
|
|
||||||
app.get(route, ngApp);
|
|
||||||
});
|
|
||||||
|
|
||||||
function serverStarted() {
|
|
||||||
console.log(`[${new Date().toTimeString()}] Listening at ${ENV_CONFIG.ui.baseUrl}`);
|
|
||||||
}
|
|
||||||
|
|
||||||
function createHttpsServer(keys) {
|
|
||||||
https.createServer({
|
|
||||||
key: keys.serviceKey,
|
|
||||||
cert: keys.certificate
|
|
||||||
}, app).listen(port, ENV_CONFIG.ui.host, () => {
|
|
||||||
serverStarted();
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
if (ENV_CONFIG.ui.ssl) {
|
|
||||||
let serviceKey;
|
|
||||||
try {
|
|
||||||
serviceKey = fs.readFileSync('./config/ssl/key.pem');
|
|
||||||
} catch (e) {
|
|
||||||
console.warn('Service key not found at ./config/ssl/key.pem');
|
|
||||||
}
|
|
||||||
|
|
||||||
let certificate;
|
|
||||||
try {
|
|
||||||
certificate = fs.readFileSync('./config/ssl/cert.pem');
|
|
||||||
} catch (e) {
|
|
||||||
console.warn('Certificate not found at ./config/ssl/key.pem');
|
|
||||||
}
|
|
||||||
|
|
||||||
if (serviceKey && certificate) {
|
|
||||||
createHttpsServer({
|
|
||||||
serviceKey: serviceKey,
|
|
||||||
certificate: certificate
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
|
|
||||||
process.env.NODE_TLS_REJECT_UNAUTHORIZED = '0';
|
|
||||||
|
|
||||||
pem.createCertificate({
|
|
||||||
days: 1,
|
|
||||||
selfSigned: true
|
|
||||||
}, (error, keys) => {
|
|
||||||
createHttpsServer(keys);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
app.listen(port, ENV_CONFIG.ui.host, () => {
|
|
||||||
serverStarted();
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
133
src/server.ts
Normal file
133
src/server.ts
Normal file
@@ -0,0 +1,133 @@
|
|||||||
|
import 'zone.js/dist/zone-node';
|
||||||
|
import 'reflect-metadata';
|
||||||
|
import 'rxjs/Rx';
|
||||||
|
|
||||||
|
import * as fs from 'fs';
|
||||||
|
import * as pem from 'pem';
|
||||||
|
import * as https from 'https';
|
||||||
|
import * as morgan from 'morgan';
|
||||||
|
import * as express from 'express';
|
||||||
|
import * as bodyParser from 'body-parser';
|
||||||
|
import * as compression from 'compression';
|
||||||
|
import * as cookieParser from 'cookie-parser';
|
||||||
|
|
||||||
|
import { enableProdMode, NgModuleFactory, Type } from '@angular/core';
|
||||||
|
|
||||||
|
import { ngExpressEngine } from '@nguniversal/express-engine';
|
||||||
|
|
||||||
|
import { ROUTES } from './routes';
|
||||||
|
import { ENV_CONFIG } from './config';
|
||||||
|
|
||||||
|
export function startServer(bootstrap: Type<{}> | NgModuleFactory<{}>) {
|
||||||
|
const app = express();
|
||||||
|
|
||||||
|
const port = ENV_CONFIG.ui.port ? ENV_CONFIG.ui.port : 80;
|
||||||
|
|
||||||
|
if (ENV_CONFIG.production) {
|
||||||
|
enableProdMode();
|
||||||
|
app.use(compression());
|
||||||
|
}
|
||||||
|
|
||||||
|
app.use(morgan('dev'));
|
||||||
|
|
||||||
|
app.use(cookieParser());
|
||||||
|
app.use(bodyParser.json());
|
||||||
|
|
||||||
|
app.engine('html', ngExpressEngine({
|
||||||
|
bootstrap: bootstrap
|
||||||
|
}));
|
||||||
|
|
||||||
|
app.set('view engine', 'html');
|
||||||
|
app.set('views', 'src');
|
||||||
|
|
||||||
|
function cacheControl(req, res, next) {
|
||||||
|
// instruct browser to revalidate
|
||||||
|
res.header('Cache-Control', ENV_CONFIG.cache.control || 'max-age=60');
|
||||||
|
next();
|
||||||
|
}
|
||||||
|
|
||||||
|
app.use('/', cacheControl, express.static('dist', { index: false }));
|
||||||
|
|
||||||
|
// TODO: either remove or update mock backend
|
||||||
|
// app.get('/data.json', serverApi);
|
||||||
|
// app.use('/api', createMockApi());
|
||||||
|
|
||||||
|
function ngApp(req, res) {
|
||||||
|
|
||||||
|
function onHandleError(parentZoneDelegate, currentZone, targetZone, error) {
|
||||||
|
console.warn('Error in SSR, serving for direct CSR');
|
||||||
|
res.sendFile('index.csr.html', { root: './src' });
|
||||||
|
}
|
||||||
|
|
||||||
|
if (ENV_CONFIG.universal.preboot) {
|
||||||
|
Zone.current.fork({ name: 'CSR fallback', onHandleError }).run(() => {
|
||||||
|
res.render('../dist/index', {
|
||||||
|
req,
|
||||||
|
res,
|
||||||
|
preboot: ENV_CONFIG.universal.preboot,
|
||||||
|
async: ENV_CONFIG.universal.async,
|
||||||
|
time: ENV_CONFIG.universal.time,
|
||||||
|
baseUrl: ENV_CONFIG.ui.nameSpace,
|
||||||
|
originUrl: ENV_CONFIG.ui.baseUrl,
|
||||||
|
requestUrl: req.originalUrl
|
||||||
|
});
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
console.log('Universal off, serving for direct CSR');
|
||||||
|
res.sendFile('index.csr.html', { root: './src' });
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
ROUTES.forEach((route: string) => {
|
||||||
|
app.get(route, ngApp);
|
||||||
|
});
|
||||||
|
|
||||||
|
function serverStarted() {
|
||||||
|
console.log(`[${new Date().toTimeString()}] Listening at ${ENV_CONFIG.ui.baseUrl}`);
|
||||||
|
}
|
||||||
|
|
||||||
|
function createHttpsServer(keys) {
|
||||||
|
https.createServer({
|
||||||
|
key: keys.serviceKey,
|
||||||
|
cert: keys.certificate
|
||||||
|
}, app).listen(port, ENV_CONFIG.ui.host, () => {
|
||||||
|
serverStarted();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
if (ENV_CONFIG.ui.ssl) {
|
||||||
|
let serviceKey;
|
||||||
|
try {
|
||||||
|
serviceKey = fs.readFileSync('./config/ssl/key.pem');
|
||||||
|
} catch (e) {
|
||||||
|
console.warn('Service key not found at ./config/ssl/key.pem');
|
||||||
|
}
|
||||||
|
|
||||||
|
let certificate;
|
||||||
|
try {
|
||||||
|
certificate = fs.readFileSync('./config/ssl/cert.pem');
|
||||||
|
} catch (e) {
|
||||||
|
console.warn('Certificate not found at ./config/ssl/key.pem');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (serviceKey && certificate) {
|
||||||
|
createHttpsServer({
|
||||||
|
serviceKey: serviceKey,
|
||||||
|
certificate: certificate
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
|
||||||
|
process.env.NODE_TLS_REJECT_UNAUTHORIZED = '0';
|
||||||
|
|
||||||
|
pem.createCertificate({
|
||||||
|
days: 1,
|
||||||
|
selfSigned: true
|
||||||
|
}, (error, keys) => {
|
||||||
|
createHttpsServer(keys);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
app.listen(port, ENV_CONFIG.ui.host, () => {
|
||||||
|
serverStarted();
|
||||||
|
});
|
||||||
|
}}
|
7
src/tsconfig.server.aot.json
Normal file
7
src/tsconfig.server.aot.json
Normal file
@@ -0,0 +1,7 @@
|
|||||||
|
{
|
||||||
|
"extends": "./tsconfig.server.json",
|
||||||
|
"angularCompilerOptions": {
|
||||||
|
"entryModule": "./modules/app/server-app.module#ServerAppModule"
|
||||||
|
},
|
||||||
|
"exclude": []
|
||||||
|
}
|
@@ -7,13 +7,13 @@
|
|||||||
"experimentalDecorators": true,
|
"experimentalDecorators": true,
|
||||||
"allowSyntheticDefaultImports": true,
|
"allowSyntheticDefaultImports": true,
|
||||||
"sourceMap": true,
|
"sourceMap": true,
|
||||||
"noEmit": true,
|
|
||||||
"noEmitHelpers": true,
|
"noEmitHelpers": true,
|
||||||
"importHelpers": true,
|
"importHelpers": true,
|
||||||
"noImplicitAny": false,
|
"noImplicitAny": false,
|
||||||
"strictNullChecks": false,
|
"strictNullChecks": false,
|
||||||
|
"skipDefaultLibCheck": true,
|
||||||
|
"pretty": true,
|
||||||
"baseUrl": ".",
|
"baseUrl": ".",
|
||||||
"paths": {},
|
|
||||||
"typeRoots": [
|
"typeRoots": [
|
||||||
"node_modules/@types"
|
"node_modules/@types"
|
||||||
],
|
],
|
||||||
@@ -22,23 +22,23 @@
|
|||||||
"node"
|
"node"
|
||||||
],
|
],
|
||||||
"lib": [
|
"lib": [
|
||||||
|
"dom",
|
||||||
|
"es6",
|
||||||
|
"es2015",
|
||||||
"es2016",
|
"es2016",
|
||||||
"dom"
|
"es2017"
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
"exclude": [
|
"exclude": [
|
||||||
"node_modules",
|
"node_modules",
|
||||||
"dist",
|
"dist",
|
||||||
"src/**/*.spec.ts",
|
"src/**/*.spec.ts",
|
||||||
"src/**/*.e2e.ts"
|
"src/**/*.e2e.ts",
|
||||||
|
"src/main.server.aot.ts"
|
||||||
],
|
],
|
||||||
"compileOnSave": false,
|
"compileOnSave": false,
|
||||||
"buildOnSave": false,
|
"buildOnSave": false,
|
||||||
"atom": {
|
"atom": {
|
||||||
"rewriteTsconfig": false
|
"rewriteTsconfig": false
|
||||||
},
|
|
||||||
"angularCompilerOptions": {
|
|
||||||
"skipTemplateCodegen": true,
|
|
||||||
"preserveWhitespaces": false
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -1,7 +1,7 @@
|
|||||||
const webpackMerge = require('webpack-merge');
|
const webpackMerge = require('webpack-merge');
|
||||||
const commonPartial = require('./webpack/webpack.common');
|
const commonPartial = require('./webpack/webpack.common');
|
||||||
const clientPartial = require('./webpack/webpack.client');
|
const clientPartial = require('./webpack/webpack.client');
|
||||||
const serverPartial = require('./webpack/webpack.server');
|
const { getServerWebpackPartial } = require('./webpack/webpack.server');
|
||||||
const prodPartial = require('./webpack/webpack.prod');
|
const prodPartial = require('./webpack/webpack.prod');
|
||||||
|
|
||||||
const {
|
const {
|
||||||
@@ -15,6 +15,8 @@ module.exports = function(options, webpackOptions) {
|
|||||||
console.log(`Running build for ${options.client ? 'client' : 'server'} with AoT Compilation`)
|
console.log(`Running build for ${options.client ? 'client' : 'server'} with AoT Compilation`)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
let serverPartial = getServerWebpackPartial(options.aot);
|
||||||
|
|
||||||
let serverConfig = webpackMerge({}, commonPartial, serverPartial, {
|
let serverConfig = webpackMerge({}, commonPartial, serverPartial, {
|
||||||
plugins: [
|
plugins: [
|
||||||
getAotPlugin('server', !!options.aot)
|
getAotPlugin('server', !!options.aot)
|
||||||
|
@@ -3,7 +3,7 @@ const {
|
|||||||
} = require('./helpers');
|
} = require('./helpers');
|
||||||
|
|
||||||
const {
|
const {
|
||||||
AotPlugin
|
AngularCompilerPlugin
|
||||||
} = require('@ngtools/webpack');
|
} = require('@ngtools/webpack');
|
||||||
|
|
||||||
const tsconfigs = {
|
const tsconfigs = {
|
||||||
@@ -11,6 +11,11 @@ const tsconfigs = {
|
|||||||
server: root('./src/tsconfig.server.json')
|
server: root('./src/tsconfig.server.json')
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const aotTsconfigs = {
|
||||||
|
client: root('./src/tsconfig.browser.json'),
|
||||||
|
server: root('./src/tsconfig.server.aot.json')
|
||||||
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Generates a AotPlugin for @ngtools/webpack
|
* Generates a AotPlugin for @ngtools/webpack
|
||||||
*
|
*
|
||||||
@@ -19,8 +24,8 @@ const tsconfigs = {
|
|||||||
* @returns {AotPlugin} Configuration of AotPlugin
|
* @returns {AotPlugin} Configuration of AotPlugin
|
||||||
*/
|
*/
|
||||||
function getAotPlugin(platform, aot) {
|
function getAotPlugin(platform, aot) {
|
||||||
return new AotPlugin({
|
return new AngularCompilerPlugin({
|
||||||
tsConfigPath: tsconfigs[platform],
|
tsConfigPath: aot ? aotTsconfigs[platform] : tsconfigs[platform],
|
||||||
skipCodeGeneration: !aot
|
skipCodeGeneration: !aot
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@@ -5,15 +5,20 @@ const {
|
|||||||
} = require('./helpers');
|
} = require('./helpers');
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
entry: root('./src/main.server.ts'),
|
getServerWebpackPartial: function (aot) {
|
||||||
output: {
|
const entry = aot ? root('./src/main.server.aot.ts') : root('./src/main.server.ts');
|
||||||
filename: 'server.js'
|
return {
|
||||||
},
|
entry: entry,
|
||||||
target: 'node',
|
output: {
|
||||||
externals: [nodeExternals({
|
filename: 'server.js'
|
||||||
whitelist: [
|
},
|
||||||
/@angular/,
|
target: 'node',
|
||||||
/@ng/,
|
externals: [nodeExternals({
|
||||||
/ngx/]
|
whitelist: [
|
||||||
})],
|
/@angular/,
|
||||||
|
/@ng/,
|
||||||
|
/ngx/]
|
||||||
|
})],
|
||||||
|
}
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
Reference in New Issue
Block a user