Skip to content

Commit

Permalink
cleanup, local development fixes and start best practices (FAForever#453
Browse files Browse the repository at this point in the history
)

* FAForever#449 remove npm lock

* Cleanup, local development improvements and applying some best practices
- removed some unused yarn deps (via npm_check)
- added missing deps (grunt did not complain on concat, but files where missing)
- removed Procfile (was prob. a leftover of a Heroku trail)
- removed .dockerignore, since it is doing nothing for the build
- fixed all of the grunt commands (that are used)
- removed grunt node-inspector -> unused
- added npm_check to find unused yarn deps and updates
- Dockerfile was updated to include some of the best practices for node-containers
- Docker compose was added for easy development with the faf-stack
- Readme updated to include local docker env setup
- Express port is now defaulting to 3000
- OAUTH_PUBLIC_URL was intruduced for docker environments (container -> container vs brower -> container) urls
- unused js files removed (no reference in the code, or empty files)

* add comments for .env vars
  • Loading branch information
fcaps authored Nov 11, 2023
1 parent 614d2bd commit d730a2c
Show file tree
Hide file tree
Showing 30 changed files with 3,761 additions and 13,065 deletions.
1 change: 0 additions & 1 deletion .dockerignore

This file was deleted.

16 changes: 7 additions & 9 deletions .env.example
Original file line number Diff line number Diff line change
@@ -1,4 +1,3 @@

PORT=3000
HOST=http://localhost:3000
API_URL=https://api.test.faforever.com
Expand All @@ -10,11 +9,10 @@ OAUTH_CLIENT_ID=faf-website
OAUTH_CLIENT_SECRET=banana
SESSION_SECRET_KEY=banana
RECAPTCHA_SITE_KEY=6Lc4GmgaAAAAAPaFbnwuP_dBGG--SSy2Hi5UcqwK


TOKEN_LIFESPAN=43200 # an api token is valid for 12h
CLAN_INVITES_LIFESPAN_DAYS = 30 # 30 days
EXTRACTOR_INTERVAL= 5 # 5 minutes
PLAYER_COUNT_INTERVAL= 15 # 15 seconds


# JAVA-API token lifetime in seconds
TOKEN_LIFESPAN=43200
CLAN_INVITES_LIFESPAN_DAYS=30
# Interval for the extractor.js in minutes
EXTRACTOR_INTERVAL=5
# Interval for the getRecentUsers.js in seconds
PLAYER_COUNT_INTERVAL=15
36 changes: 36 additions & 0 deletions .env.faf-stack
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
# node env is set statically to "development" in the dockerfile, you could override it here.
#NODE_ENV=production

# you should not need to change the port (used by express) inside the container, just here for completion
#PORT=3000

# configs to change the ports in docker compose for the container
# only needed if your host already has 8020 binded to another service
# beware, changing the host port (8020) also needs an update in the hydra client for valid callback-urls
#WEBSITE_EXPOSED_PORT=8020
#WEBSITE_CONTAINER_PORT=3000

HOST=http://localhost:8020
API_URL=http://faf-java-api:8010
OAUTH_URL=http://faf-ory-hydra:4444

# on a local environment with docker, the internal docker-service-domain (faf-ory-hydra:4444) is not reachable for a browser
# you can omit this env and it will fallback to OAUTH_URL if you know what you are doing.
OAUTH_PUBLIC_URL=http://localhost:4444

# unsing the "production" wordpress because the faf-local-stack is just an empty instance without any news etc.
WP_URL=https://direct.faforever.com

LOBBY_API_URL=http://faf-python-server:4000

OAUTH_CLIENT_ID=faf-website
OAUTH_CLIENT_SECRET=banana
SESSION_SECRET_KEY=banana
RECAPTCHA_SITE_KEY=6LeIxAcTAAAAAJcZVRqyHh71UMIEGNQ_MXjiZKhI
# JAVA-API token lifetime in seconds
TOKEN_LIFESPAN=43200
CLAN_INVITES_LIFESPAN_DAYS=30
# Interval for the extractor.js in minutes
EXTRACTOR_INTERVAL=5
# Interval for the getRecentUsers.js in seconds
PLAYER_COUNT_INTERVAL=15
15 changes: 0 additions & 15 deletions .gitattributes
Original file line number Diff line number Diff line change
@@ -1,17 +1,2 @@
# Auto detect text files and perform LF normalization
* text=auto

# Custom for Visual Studio
*.cs diff=csharp

# Standard to msysgit
*.doc diff=astextplain
*.DOC diff=astextplain
*.docx diff=astextplain
*.DOCX diff=astextplain
*.dot diff=astextplain
*.DOT diff=astextplain
*.pdf diff=astextplain
*.PDF diff=astextplain
*.rtf diff=astextplain
*.RTF diff=astextplain
20 changes: 20 additions & 0 deletions .github/workflows/code-quality.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
name: Website static checks

on: [pull_request]

concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true

jobs:
checks:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: actions/setup-node@v3
with:
node-version: '20'
cache: 'yarn'
- run: yarn install
# --force should be removed if all the issues are fixed
- run: ./node_modules/.bin/grunt jshint --force
4 changes: 3 additions & 1 deletion .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -46,4 +46,6 @@ public/styles/css/*
.env

#Ignore link.json
link.json
link.json

public/js/*.js
16 changes: 16 additions & 0 deletions .npmcheckrc
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
depcheck:
ignoreMatches: [
"npm-check", # used manually to check for updates
"pug", # used in express as the template engine
"awesomplete", # used statically in grunt/concat.js

# grunt plugins used in "./grunt"
"grunt-sass",
"grunt-postcss",
"grunt-nodemon",
"grunt-contrib-watch",
"grunt-contrib-uglify-es",
"grunt-contrib-jshint",
"grunt-contrib-concat",
"grunt-concurrent"
]
29 changes: 12 additions & 17 deletions Dockerfile
Original file line number Diff line number Diff line change
@@ -1,27 +1,22 @@
# Use an ubuntu-image for building assets for use in a runtime image...
FROM node:lts as builder

RUN mkdir code

# Add files to /code folder
ADD . /code
FROM node:20.9-bookworm as builder
RUN apt-get update && apt-get install -y --no-install-recommends dumb-init
ENV NODE_ENV development

COPY . /code
WORKDIR /code

RUN yarn install

RUN yarn install --production=false --frozen-lockfile
RUN ./node_modules/.bin/grunt prod
RUN yarn install --production=true --ignore-optional --frozen-lockfile

# Slimmer runtime image without python/make/gcc etc.
FROM node:lts-alpine as runtime
FROM node:20.9.0-bookworm-slim as runtime
ENV NODE_ENV production

COPY --from=builder /code /code
COPY --from=builder /usr/bin/dumb-init /usr/bin/dumb-init
COPY --from=builder --chown=node:node /code /code

WORKDIR /code
USER node

# Only install runtime dependencies for the runtime image
RUN yarn --prod

CMD PORT=3000 npm start
CMD ["dumb-init", "node", "express.js"]

EXPOSE 3000
6 changes: 6 additions & 0 deletions Dockerfile-dev
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
FROM node:20.9-bookworm
RUN apt-get update && apt-get install -y --no-install-recommends dumb-init
ENV NODE_ENV development
WORKDIR /code

CMD ["dumb-init", "./node_modules/.bin/grunt", "concurrent"]
28 changes: 0 additions & 28 deletions Gruntfile.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,9 +5,6 @@ module.exports = function(grunt) {
// Load grunt tasks automatically
require('load-grunt-tasks')(grunt);

// Time how long tasks take. Can help when optimizing build times
require('time-grunt')(grunt);

var options = {
config: {
src: './grunt/*.js'
Expand All @@ -23,34 +20,9 @@ module.exports = function(grunt) {
// Project configuration.
grunt.initConfig(configs);

// load jshint
grunt.registerTask('lint', [
'jshint'
]);

// default option to connect server
grunt.registerTask('serve', [
'jshint',
'concurrent:dev'
]);

grunt.registerTask('prod', [
'sass:dist',
'concat:js',
'uglify:dist'
]);

grunt.registerTask('server', function () {
grunt.log.warn('The `server` task has been deprecated. Use `grunt serve` to start a server.');
grunt.task.run(['serve:' + target]);
});

if(process.env.NODE_ENV === "development") {
grunt.loadNpmTasks('grunt-contrib-compass');
grunt.loadNpmTasks('grunt-contrib-uglify-es');
grunt.loadNpmTasks('grunt-sass');
grunt.loadNpmTasks('grunt-contrib-concat');
grunt.loadNpmTasks('grunt-contrib-jshint');
grunt.loadNpmTasks('grunt-postcss');
}
};
1 change: 0 additions & 1 deletion Procfile

This file was deleted.

36 changes: 29 additions & 7 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -12,13 +12,35 @@ The Main Focus for what the primary purpose of the website is. The following was
1. To Focus on Acquiring and On-boarding of new Player into FAForever (Registration of players, Documentation & Support)
2. Promote The Community (Clans, Maps, Mods, Tournaments etc.)

## Developing the Website / Setting up your local enviroment

If you want to setup your own local enviroment, there's a guide below.

https://github.com/FAForever/website/wiki/Setting-up-a-local-environment-for-the-website

For any PR/Pull Request, please make sure you detail in the comments on files/changes. Otherwise it might take longer for your change to be approved.
## Developing the Website / Setting up your local environment

### Option #1 - locally install node, yarn etc
Local installation without docker [guide](https://github.com/FAForever/website/wiki/Setting-up-a-local-environment-for-the-website)

### Option #2 - run everything in docker (linux, wsl2, mac)
Local requirements:
- docker
- docker compose

The website has dependencies to Hydra, [Lobby](https://github.com/FAForever/server), Wordpress and the [Java-API](https://github.com/FAForever/faf-java-api).
You can run those with the [local-stack](https://github.com/FAForever/faf-stack).

If you got the [local-stack](https://github.com/FAForever/faf-stack) up and running, we need to stop the "faf-website" and replace it with a development container.
````bash
cd ../faf-stack # replace path if needed
docker compose stop faf-website
````

Development-Container:
`````bash
cd ../website # replace path if needed
cp -n .env.faf-stack .env
docker compose build
docker compose run website yarn install
docker compose up
`````

this should start the express-server on http://localhost:8020/.

## Other Ways to Contribute

Expand Down
19 changes: 19 additions & 0 deletions docker-compose.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
version: "3.5"

services:
website:
env_file: .env
ports:
- ${WEBSITE_EXPOSED_PORT-8020}:${WEBSITE_CONTAINER_PORT-3000}
volumes:
- .:/code
build:
dockerfile: Dockerfile-dev
context: .
networks:
- faf-stack

networks:
faf-stack:
name: faf-stack_faf
external: true
5 changes: 3 additions & 2 deletions express.js
Original file line number Diff line number Diff line change
Expand Up @@ -17,9 +17,10 @@ app.locals.clanInvitations = {};
require('dotenv').config();
//Define environment variables with default values
process.env.NODE_ENV = process.env.NODE_ENV || 'production';
process.env.PORT = process.env.PORT || '4000';
process.env.PORT = process.env.PORT || '3000';
process.env.CALLBACK = process.env.CALLBACK || 'callback';
process.env.OAUTH_URL = process.env.OAUTH_URL || 'https://hydra.faforever.com';
process.env.OAUTH_PUBLIC_URL = process.env.OAUTH_PUBLIC_URL || process.env.OAUTH_URL;
process.env.API_URL = process.env.API_URL || 'https://api.faforever.com';
process.env.OAUTH_CLIENT_ID = process.env.OAUTH_CLIENT_ID || '12345';
process.env.OAUTH_CLIENT_SECRET = process.env.OAUTH_CLIENT_SECRET || '12345';
Expand Down Expand Up @@ -227,7 +228,7 @@ app.get('/login', passport.authenticate('faforever'));
passport.use('faforever', new OidcStrategy({
issuer: process.env.OAUTH_URL + '/',
tokenURL: process.env.OAUTH_URL + '/oauth2/token',
authorizationURL: process.env.OAUTH_URL + '/oauth2/auth',
authorizationURL: process.env.OAUTH_PUBLIC_URL + '/oauth2/auth',
userInfoURL: process.env.OAUTH_URL + '/userinfo?schema=openid',
clientID: process.env.OAUTH_CLIENT_ID,
clientSecret: process.env.OAUTH_CLIENT_SECRET,
Expand Down
22 changes: 1 addition & 21 deletions grunt/concat.js
Original file line number Diff line number Diff line change
@@ -1,37 +1,17 @@
module.exports = {
js: {
nonull: true,
files: {
'public/js/bottom.min.js': [
'public/js/app/headroom.min.js',
'public/js/app/navigation.js'
],
'public/js/leaderboards.min.js': [
'node_modules/awesomplete/awesomplete.js',
'node_modules/moment/min/moment-with-locales.min.js',
'public/js/app/leaderboards.js'
],
'public/js/leagues.min.js': [
'node_modules/awesomplete/awesomplete.js',
'node_modules/moment/min/moment-with-locales.min.js',
'public/js/app/leagues.js'
],
'public/js/account.min.js': [
'node_modules/bootstrap-validator/dist/validator.js'
],
'public/js/blog.min.js': [
'public/js/app/blog.js'
],
'public/js/newshub.min.js': [
'public/js/app/newshub.js'
],
'public/js/report.min.js': [
'node_modules/awesomplete/awesomplete.js',
'public/js/app/report.js'
],
'public/js/browse_clans.min.js': [
'node_modules/awesomplete/awesomplete.js',
'public/js/app/browse_clans.js'
]
}
}
};
2 changes: 1 addition & 1 deletion grunt/concurrent.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
module.exports = {
dev: {
tasks: ['nodemon:debug', 'concat:js', 'uglify:dev', 'watch'],
tasks: ['nodemon', 'concat', 'watch'],
options: {
logConcurrentOutput: true
}
Expand Down
31 changes: 22 additions & 9 deletions grunt/jshint.js
Original file line number Diff line number Diff line change
@@ -1,13 +1,26 @@
module.exports = {
options: {
reporter: require('jshint-stylish'),
force: true
},
all: [
'routes/**/*.js',
'models/**/*.js'
],
server: [
'./express.js'
]
};
browser_files: {
options: {
esversion: 8,
asi: true
},
src: [
'public/js/app/**/*js',
]
},
node_files: {
options: {
node: true,
esversion: 11,
asi: true
},
src: [
'./express.js',
'scripts/**/*js',
'routes/**/*js',
]
}
};
7 changes: 0 additions & 7 deletions grunt/node-inspector.js

This file was deleted.

Loading

0 comments on commit d730a2c

Please sign in to comment.