Documentation / Demo

GROWI =========== [![wercker status](https://app.wercker.com/status/595b761d0e26796ddb304679f7bf27de/s/master "wercker status")](https://app.wercker.com/project/byKey/595b761d0e26796ddb304679f7bf27de) [![dependencies status](https://david-dm.org/weseek/growi.svg)](https://david-dm.org/weseek/growi) [![devDependencies Status](https://david-dm.org/weseek/growi/dev-status.svg)](https://david-dm.org/weseek/growi?type=dev) [![docker pulls](https://img.shields.io/docker/pulls/weseek/growi.svg)](https://hub.docker.com/r/weseek/growi/) - [Features](#features) - [Quick Start for Production](#quick-start-for-production) - [Heroku](#heroku) - [docker-compose](#docker-compose) - [On-premise](#on-premise) - [Environment Variables](#environment-variables) - [Documentation](#documentation) - [License](#license) Features ======== * **Features** * Create hierarchical pages with markdown -> [HERE](https://docs.growi.org/en/guide/getting-started/five_minutes.html) is 5 minutes tutorial * Simultaneously edit with multiple people by [HackMD(CodiMD)](https://hackmd.io/) integration * [GROWI Docs: HackMD(CodiMD) Integration](https://docs.growi.org/en/admin-guide/admin-cookbook/integrate-with-hackmd.html) * Support Authentication with LDAP / Active Directory, OAuth * SSO(Single Sign On) with SAML * Slack/Mattermost, IFTTT Integration * [GROWI Docs: Features](https://docs.growi.org/en/guide/features/page_layout.html) * **Pluggable** * You can find plugins from [npm](https://www.npmjs.com/browse/keyword/growi-plugin) or [github](https://github.com/search?q=topic%3Agrowi-plugin)! * **[Docker Ready][dockerhub]** * **[Docker Compose Ready][docker-compose]** * [GROWI Docs: Multiple sites](https://docs.growi.org/en/admin-guide/admin-cookbook/multi-app.html) * [GROWI Docs: HTTPS(with Let's Encrypt) proxy integration](https://docs.growi.org/en/admin-guide/admin-cookbook/lets-encrypt.html) Quick Start for Production =========================== ### Heroku - [GROWI Docs: Launch on Heroku](https://docs.growi.org/en/admin-guide/getting-started/heroku.html) ([en](https://docs.growi.org/en/admin-guide/getting-started/heroku.html)/[ja](https://docs.growi.org/ja/admin-guide/getting-started/heroku.html)) ### docker-compose - [GROWI Docs: Launch with docker-compose](https://docs.growi.org/en/admin-guide/getting-started/docker-compose.html) ([en](https://docs.growi.org/en/admin-guide/getting-started/docker-compose.html)/[ja](https://docs.growi.org/ja/admin-guide/getting-started/docker-compose.html)) ### On-premise **[Migration Guide from Crowi](https://docs.growi.org/en/admin-guide/migration-guide/from-crowi-onpremise.html) ([en](https://docs.growi.org/en/admin-guide/migration-guide/from-crowi-onpremise.html)/[ja](https://docs.growi.org/ja/admin-guide/migration-guide/from-crowi-onpremise.html))** is here. - [GROWI Docs: Install on Ubuntu Server](https://docs.growi.org/en/admin-guide/getting-started/ubuntu-server.html) - [GROWI Docs: Install on CentOS](https://docs.growi.org/en/admin-guide/getting-started/centos.html) Development ========== ## Dependencies - Node.js v10.x (DON'T USE 11.x) - npm 6.x - yarn - MongoDB 3.x See [confirmed versions](https://docs.growi.org/en/dev/startup/dev-env.html#set-up-node-js-environment). ### Optional Dependencies - Redis 3.x - ElasticSearch 6.x (needed when using Full-text search) - **CAUTION: Following plugins are required** - [Japanese (kuromoji) Analysis plugin](https://www.elastic.co/guide/en/elasticsearch/plugins/current/analysis-kuromoji.html) - [ICU Analysis Plugin](https://www.elastic.co/guide/en/elasticsearch/plugins/current/analysis-icu.html) ## Command details |command|desc| |--|--| |`npm run build:prod`|Build the client| |`npm run server:prod`|Launch the server| |`npm start`|Invoke `npm run build:prod` and `npm run server:prod`| For more info, see [GROWI Docs: List of npm Commands](https://docs.growi.org/en/dev/startup/launch.html#list-of-npm-commands). Environment Variables ====================== * **Required** * MONGO_URI: URI to connect to MongoDB. * **Option** * NODE_ENV: `production` OR `development`. * PORT: Server port. default: `3000`. * NO_CDN: If `true`, system doesn't use CDN, all resources will be downloaded from CDN when build client, and served by the GROWI Express server. default: `false`. * ELASTICSEARCH_URI: URI to connect to Elasticearch. * REDIS_URI: URI to connect to Redis (use it as a session store instead of MongoDB). * PASSWORD_SEED: A password seed used by password hash generator. * SECRET_TOKEN: A secret key for verifying the integrity of signed cookies. * SESSION_NAME: The name of the session ID cookie to set in the response by Express. default: `connect.sid` * SAML_USES_ONLY_ENV_VARS_FOR_SOME_OPTIONS: If `true`, the system uses only the value of the environment variable as the value of the SAML option that can be set via the environment variable. * PUBLISH_OPEN_API: Publish GROWI OpenAPI resources with [ReDoc](https://github.com/Rebilly/ReDoc). Visit `/api-docs`. * FORCE_WIKI_MODE: Forces wiki mode. default: undefined * `public` : Forces all pages to become public * `private` : Forces all pages to become private * undefined : Publicity will be configured by the admin security page settings * FORMAT_NODE_LOG: If `false`, Output server log as JSON. defautl: `true` (Enabled only when `NODE_ENV=production`) * **Option for file uploading** * FILE_UPLOAD: Attached files storage. default: `aws` * `aws` : Amazon Web Service S3 (needs AWS settings on Admin page) * `gcs` : Google Cloud Storage (needs settings with environment variables) * `mongodb` : MongoDB GridFS (Setting-less) * `local` : Server's Local file system (Setting-less) * `none` : Disable file uploading * FILE_UPLOAD_DISABLED: If `true`, disabled file upload. However can view files. default: `false` * MAX_FILE_SIZE: The maximum file size limit for uploads (bytes). default: `Infinity` * FILE_UPLOAD_TOTAL_LIMIT: Total capacity limit for uploads (bytes). default: `Infinity` * GCS_API_KEY_JSON_PATH: Path of the JSON file that contains [service account key to authenticate to GCP API](https://cloud.google.com/iam/docs/creating-managing-service-account-keys) * GCS_BUCKET: Name of the GCS bucket * GCS_UPLOAD_NAMESPACE: Directory name to create in the bucket * MONGO_GRIDFS_TOTAL_LIMIT: Total capacity limit of MongoDB GridFS (bytes). default: `Infinity` * MONGO_GRIDFS_TOTAL_LIMIT setting takes precedence over FILE_UPLOAD_TOTAL_LIMIT. * **Option to integrate with external systems** * HACKMD_URI: URI to connect to [HackMD(CodiMD)](https://hackmd.io/) server. * **This server must load the GROWI agent. [Here's how to prepare it](https://docs.growi.org/guide/admin-cookbook/integrate-with-hackmd.html).** * HACKMD_URI_FOR_SERVER: URI to connect to [HackMD(CodiMD)](https://hackmd.io/) server from GROWI Express server. If not set, `HACKMD_URI` will be used. * PLANTUML_URI: URI to connect to [PlantUML](http://plantuml.com/) server. * BLOCKDIAG_URI: URI to connect to [blockdiag](http://http://blockdiag.com/) server. * **Option (Overwritable in admin page)** * APP_SITE_URL: Site URL. e.g. `https://example.com`, `https://example.com:8080` * LOCAL_STRATEGY_ENABLED: Enable or disable ID/Pass login * LOCAL_STRATEGY_USES_ONLY_ENV_VARS_FOR_SOME_OPTIONS: Prioritize env vars than values in DB for some ID/Pass login options * SAML_ENABLED: Enable or disable SAML * SAML_USES_ONLY_ENV_VARS_FOR_SOME_OPTIONS: Prioritize env vars than values in DB for some SAML options * SAML_ENTRY_POINT: IdP entry point * SAML_ISSUER: Issuer string to supply to IdP * SAML_ATTR_MAPPING_ID: Attribute map for id * SAML_ATTR_MAPPING_USERNAME: Attribute map for username * SAML_ATTR_MAPPING_MAIL: Attribute map for email * SAML_ATTR_MAPPING_FIRST_NAME: Attribute map for first name * SAML_ATTR_MAPPING_LAST_NAME: Attribute map for last name * SAML_CERT: PEM-encoded X.509 signing certificate string to validate the response from IdP * OAUTH_GOOGLE_CLIENT_ID: Google API client id for OAuth login. * OAUTH_GOOGLE_CLIENT_SECRET: Google API client secret for OAuth login. * OAUTH_GITHUB_CLIENT_ID: GitHub API client id for OAuth login. * OAUTH_GITHUB_CLIENT_SECRET: GitHub API client secret for OAuth login. * OAUTH_TWITTER_CONSUMER_KEY: Twitter consumer key(API key) for OAuth login. * OAUTH_TWITTER_CONSUMER_SECRET: Twitter consumer secret(API secret) for OAuth login. Documentation ============== - [GROWI Docs](https://docs.growi.org/) - [GROWI Developers Wiki (ja)](https://dev.growi.org/) Contribution ============ Found a Bug? ------------- If you found a bug in the source code, you can help us by [submitting an issue][issues] to our [GitHub Repository][growi]. Even better, you can [submit a Pull Request][pulls] with a fix. Missing a Feature? ------------------- You can *request* a new feature by [submitting an issue][issues] to our GitHub Repository. If you would like to *implement* a new feature, firstly please submit the issue with your proposal to make sure we can confirm it. Please clarify what kind of change you would like to propose. * For a **Major Feature**, firstly open an issue and outline your proposal so it can be discussed. It also allows us to coordinate better, prevent duplication of work and help you to create the change so it can be successfully accepted into the project. * **Small Features** can be created and directly [submitted as a Pull Request][pulls]. Language on GitHub ------------------ You can write issues and PRs in English or Japanese. Discussion ----------- If you have questions or suggestions, you can [join our Slack team](https://growi-slackin.weseek.co.jp/) and talk about anything, anytime. License ======= * The MIT License (MIT) * See [LICENSE](https://github.com/weseek/growi/blob/master/LICENSE) and [THIRD-PARTY-NOTICES.md](https://github.com/weseek/growi/blob/master/THIRD-PARTY-NOTICES.md). [crowi]: https://github.com/crowi/crowi [growi]: https://github.com/weseek/growi [issues]: https://github.com/weseek/growi/issues [pulls]: https://github.com/weseek/growi/pulls [dockerhub]: https://hub.docker.com/r/weseek/growi [docker-compose]: https://github.com/weseek/growi-docker-compose