mirror of
				https://github.com/gristlabs/grist-core.git
				synced 2025-06-13 20:53:59 +00:00 
			
		
		
		
	Make server take into account GRIST_SERVERS (#659)
Also ensure that only a home server will setup the database. resolves #654 Co-authored-by: Florent FAYOLLE <florent.fayolle@beta.gouv.fr>
This commit is contained in:
		
							parent
							
								
									6dab12f301
								
							
						
					
					
						commit
						1ac15912b1
					
				@ -282,6 +282,7 @@ GRIST_PAGE_TITLE_SUFFIX | a string to append to the end of the `<title>` in HTML
 | 
			
		||||
GRIST_PROXY_AUTH_HEADER | header which will be set by a (reverse) proxy webserver with an authorized users' email. This can be used as an alternative to a SAML service. See also GRIST_FORWARD_AUTH_HEADER.
 | 
			
		||||
GRIST_ROUTER_URL | optional url for an api that allows servers to be (un)registered with a load balancer
 | 
			
		||||
GRIST_SERVE_SAME_ORIGIN | set to "true" to access home server and doc workers on the same protocol-host-port as the top-level page, same as for custom domains (careful, host header should be trustworthy)
 | 
			
		||||
GRIST_SERVERS | the types of server to setup. Comma separated values which may contain "home", "docs", static" and/or "app". Defaults to "home,docs,static".
 | 
			
		||||
GRIST_SESSION_COOKIE | if set, overrides the name of Grist's cookie
 | 
			
		||||
GRIST_SESSION_DOMAIN | if set, associates the cookie with the given domain - otherwise defaults to GRIST_DOMAIN
 | 
			
		||||
GRIST_SESSION_SECRET | a key used to encode sessions
 | 
			
		||||
 | 
			
		||||
@ -15,7 +15,7 @@ export type ServerType = "home" | "docs" | "static" | "app";
 | 
			
		||||
const allServerTypes: ServerType[] = ["home", "docs", "static", "app"];
 | 
			
		||||
 | 
			
		||||
// Parse a comma-separate list of server types into an array, with validation.
 | 
			
		||||
function parseServerTypes(serverTypes: string|undefined): ServerType[] {
 | 
			
		||||
export function parseServerTypes(serverTypes: string|undefined): ServerType[] {
 | 
			
		||||
  // Split and filter out empty strings (including the one we get when splitting "").
 | 
			
		||||
  const types = (serverTypes || "").trim().split(',').filter(part => Boolean(part));
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
@ -34,7 +34,7 @@ if (!process.env.GRIST_SINGLE_ORG) {
 | 
			
		||||
setDefaultEnv('GRIST_UI_FEATURES', 'helpCenter,billing,templates,multiSite,multiAccounts,sendToDrive');
 | 
			
		||||
setDefaultEnv('GRIST_WIDGET_LIST_URL', commonUrls.gristLabsWidgetRepository);
 | 
			
		||||
import {updateDb} from 'app/server/lib/dbUtils';
 | 
			
		||||
import {main as mergedServerMain} from 'app/server/mergedServerMain';
 | 
			
		||||
import {main as mergedServerMain, parseServerTypes} from 'app/server/mergedServerMain';
 | 
			
		||||
import * as fse from 'fs-extra';
 | 
			
		||||
 | 
			
		||||
const G = {
 | 
			
		||||
@ -48,19 +48,7 @@ function setDefaultEnv(name: string, value: string) {
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// tslint:disable:no-console
 | 
			
		||||
export async function main() {
 | 
			
		||||
  console.log('Welcome to Grist.');
 | 
			
		||||
  if (!debugging) {
 | 
			
		||||
    console.log(`In quiet mode, see http://localhost:${G.port} to use.`);
 | 
			
		||||
    console.log('For full logs, re-run with DEBUG=1');
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  // If SAML is not configured, there's no login system, so provide a default email address.
 | 
			
		||||
  setDefaultEnv('GRIST_DEFAULT_EMAIL', 'you@example.com');
 | 
			
		||||
  // Set directory for uploaded documents.
 | 
			
		||||
  setDefaultEnv('GRIST_DATA_DIR', 'docs');
 | 
			
		||||
  await fse.mkdirp(process.env.GRIST_DATA_DIR!);
 | 
			
		||||
async function setupDb() {
 | 
			
		||||
  // Make a blank db if needed.
 | 
			
		||||
  if (process.env.TEST_CLEAN_DATABASE) {
 | 
			
		||||
    const {createInitialDb} = require('test/gen-server/seed');
 | 
			
		||||
@ -104,9 +92,33 @@ export async function main() {
 | 
			
		||||
      }));
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// tslint:disable:no-console
 | 
			
		||||
export async function main() {
 | 
			
		||||
  console.log('Welcome to Grist.');
 | 
			
		||||
  if (!debugging) {
 | 
			
		||||
    console.log(`In quiet mode, see http://localhost:${G.port} to use.`);
 | 
			
		||||
    console.log('For full logs, re-run with DEBUG=1');
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  // If SAML is not configured, there's no login system, so provide a default email address.
 | 
			
		||||
  setDefaultEnv('GRIST_DEFAULT_EMAIL', 'you@example.com');
 | 
			
		||||
  // Set directory for uploaded documents.
 | 
			
		||||
  setDefaultEnv('GRIST_DATA_DIR', 'docs');
 | 
			
		||||
  setDefaultEnv('GRIST_SERVERS', 'home,docs,static');
 | 
			
		||||
  const serverTypes = parseServerTypes(process.env.GRIST_SERVERS);
 | 
			
		||||
 | 
			
		||||
  await fse.mkdirp(process.env.GRIST_DATA_DIR!);
 | 
			
		||||
 | 
			
		||||
  if (serverTypes.includes("home")) {
 | 
			
		||||
    console.log('Setting up database...');
 | 
			
		||||
    await setupDb();
 | 
			
		||||
    console.log('Database setup complete.');
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  // Launch single-port, self-contained version of Grist.
 | 
			
		||||
  const server = await mergedServerMain(G.port, ["home", "docs", "static"]);
 | 
			
		||||
  const server = await mergedServerMain(G.port, serverTypes);
 | 
			
		||||
  if (process.env.GRIST_TESTING_SOCKET) {
 | 
			
		||||
    await server.addTestingHooks();
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
		Loading…
	
		Reference in New Issue
	
	Block a user