Skip to content
This repository has been archived by the owner on Jul 6, 2023. It is now read-only.

Commit

Permalink
build(npm): add npm package deployment
Browse files Browse the repository at this point in the history
* build(npm): add config to allow synclounge to be published as a package

* build(npm): add npm publish logic

* docs(linux): change installation to use npm registry

* ci(travis-ci): skip build on install
  • Loading branch information
ttshivers authored Aug 31, 2020
1 parent 91357d8 commit f86e7de
Show file tree
Hide file tree
Showing 11 changed files with 87 additions and 31 deletions.
18 changes: 15 additions & 3 deletions .github/workflows/release.yml
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,8 @@ jobs:
key: client-${{ hashFiles('**/package-lock.json') }}

- run: npm ci
env:
SKIP_BUILD: true
- run: npm run lint -- --no-fix

release:
Expand All @@ -36,6 +38,8 @@ jobs:
steps:
- uses: actions/checkout@v2
- run: npm ci
env:
SKIP_BUILD: true
- id: release
name: semantic-release
uses: ahmadnassri/action-semantic-release@v1
Expand Down Expand Up @@ -95,11 +99,15 @@ jobs:
-
name: Cache Docker layers
uses: actions/cache@v2
env:
cache-name: cache-buildx
id: cache
with:
path: /tmp/.buildx-cache
key: ${{ runner.os }}-buildx-${{ github.sha }}
key: ${{ runner.os }}-buildx-${{ hashFiles('**/package-lock.json') }}-${{ github.sha }}-${{ env.cache-name }}
restore-keys: |
${{ runner.os }}-buildx-${{ hashFiles('**/package-lock.json') }}-${{ github.sha }}
${{ runner.os }}-buildx-${{ hashFiles('**/package-lock.json') }}
${{ runner.os }}-buildx-
-
name: Docker Buildx (build)
Expand Down Expand Up @@ -160,12 +168,16 @@ jobs:
-
name: Cache Docker layers
uses: actions/cache@v2
env:
cache-name: cache-buildx-web
id: cache
with:
path: /tmp/.buildx-cache
key: ${{ runner.os }}-web-buildx-${{ github.sha }}
key: ${{ runner.os }}-buildx-${{ hashFiles('**/package-lock.json') }}-${{ github.sha }}-${{ env.cache-name }}
restore-keys: |
${{ runner.os }}-web-buildx-
${{ runner.os }}-buildx-${{ hashFiles('**/package-lock.json') }}-${{ github.sha }}
${{ runner.os }}-buildx-${{ hashFiles('**/package-lock.json') }}
${{ runner.os }}-buildx-
-
name: Docker Buildx (build)
run: |
Expand Down
10 changes: 9 additions & 1 deletion .releaserc
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@
{ "type": "refactor", "release": "patch" }
]
}],

["@semantic-release/release-notes-generator", {
"preset": "conventionalcommits",
"presetConfig": {
Expand All @@ -30,6 +31,13 @@
]
}
}],
"@semantic-release/github"

["@semantic-release/npm", {
"tarballDir": "package"
}],

["@semantic-release/github", {
"assets": "package/*.tgz"
}]
]
}
3 changes: 3 additions & 0 deletions .travis.yml
Original file line number Diff line number Diff line change
Expand Up @@ -11,5 +11,8 @@ arch:

os: linux # different CPU architectures are only supported on Linux

env:
- SKIP_BUILD=true

script:
- npm run build
4 changes: 2 additions & 2 deletions Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ FROM --platform=$BUILDPLATFORM node:current-alpine as build-stage
RUN mkdir /app && chown -R node:node /app
WORKDIR /app
COPY --chown=node:node package*.json ./
RUN npm ci
RUN SKIP_BUILD=true npm ci
COPY --chown=node:node . .

ARG VERSION
Expand All @@ -18,7 +18,7 @@ WORKDIR /app
RUN apk add --no-cache python make g++
USER node
COPY --chown=node:node package*.json ./
RUN npm ci --only=production
RUN SKIP_BUILD=true npm ci --only=production

# production environment
FROM node:current-alpine as production-stage
Expand Down
2 changes: 1 addition & 1 deletion Dockerfile.web
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ FROM --platform=$BUILDPLATFORM node:current-alpine as build-stage
RUN mkdir /app && chown -R node:node /app
WORKDIR /app
COPY --chown=node:node package*.json ./
RUN npm ci
RUN SKIP_BUILD=true npm ci
COPY --chown=node:node . .

ARG SERVERS
Expand Down
16 changes: 6 additions & 10 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -113,21 +113,17 @@ docker run -p 8080:8088 ttshivers/synclounge:latest
You can use environment variables to change any of the [default configuration](https://github.com/ttshivers/synclounge/blob/master/config/defaults.js).

#### Linux (Without Docker)
Make sure you have git, nodejs, and npm installed. Then, clone and build the repository
Make sure you have nodejs installed.
```sh
git clone https://github.com/ttshivers/synclounge.git
cd synclounge
# Install dependencies
npm ci
npm run build
sudo npm install -g synclounge
```

Once it's build, you can run it
```sh
./server.js
Then you can run it:
```
synclounge
```

If you want to change any of the [default configuration](https://github.com/ttshivers/synclounge/blob/master/config/defaults.js), you can either use environment variables with the same name, use command line arguments, or edit `dist/config.json`. If you rebuild, `dist/config.json` will be overwritten, so be aware.
If you want to change any of the [default configuration](https://github.com/ttshivers/synclounge/blob/master/config/defaults.js), you can either use environment variables with the same name, use command line arguments, or use a config file and run synclounge like `synclounge --config_file /path/to/config.json`


### Older Help
Expand Down
1 change: 0 additions & 1 deletion config/defaults.js
Original file line number Diff line number Diff line change
Expand Up @@ -56,7 +56,6 @@ const defaults = {

// Sync flexibility when players are paused
paused_sync_flexibility: 10,

};

module.exports = defaults;
14 changes: 10 additions & 4 deletions config/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -37,13 +37,19 @@ const get = (file, blockList = []) => {

'default_slplayer_quality',
]),
})
.file({ file })
.defaults(defaults);
});

const configFile = nconf.get('config_file') || file;

if (configFile) {
nconf.file({ file: configFile });
}

nconf.defaults(defaults);

// Filter out the weird stuff
const {
type, $0: firstArg, _: command, modern, ...config
config_file: no, type, $0: firstArg, _: command, modern, ...config
} = nconf.get();

// Remove blockList items
Expand Down
24 changes: 23 additions & 1 deletion package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

15 changes: 11 additions & 4 deletions package.json
Original file line number Diff line number Diff line change
@@ -1,14 +1,20 @@
{
"name": "synclounge",
"version": "0.0.0-semantically-released",
"private": false,
"description": "Synced playback of Plex content",
"author": "samcm",
"bin": "./server.js",
"files": [
"dist",
"config",
"server.js"
],
"scripts": {
"serve": "vue-cli-service serve",
"build": "vue-cli-service build --modern",
"lint": "vue-cli-service lint",
"lint:style": "vue-cli-service lint:style"
"lint:style": "vue-cli-service lint:style",
"prepare": "if-env SKIP_BUILD=true && echo 'Skipping build' || npm run build"
},
"dependencies": {
"nconf": "^0.10.0",
Expand All @@ -19,6 +25,7 @@
"@babel/plugin-proposal-optional-chaining": "^7.11.0",
"@commitlint/cli": "^9.1.2",
"@commitlint/config-conventional": "^9.1.2",
"@delucis/if-env": "^1.1.2",
"@samhammer/vue-cli-plugin-stylelint": "^2.0.0",
"@vue/cli-plugin-babel": "^4.5.4",
"@vue/cli-plugin-eslint": "^4.5.4",
Expand Down Expand Up @@ -67,6 +74,6 @@
"license": "MIT",
"repository": {
"type": "git",
"url": "git+https://github.com/ttshivers/synclounge.git"
"url": "https://github.com/ttshivers/synclounge.git"
}
}
}
11 changes: 7 additions & 4 deletions server.js
Original file line number Diff line number Diff line change
Expand Up @@ -12,14 +12,17 @@ const handle = (signal) => {
process.on('SIGINT', handle);
process.on('SIGTERM', handle);

const configFile = 'dist/config.json';
const blockList = Object.keys(syncloungeSocket.defaultConfig);
const appConfig = config.get(configFile, blockList);
const appConfig = config.get(null, blockList);
console.log(appConfig);
config.save(appConfig, configFile);

const socketConfig = syncloungeSocket.getConfig();
syncloungeSocket.socketServer({
const router = syncloungeSocket.socketServer({
...socketConfig,
static_path: 'dist',
});

// Add route for config
router.get('/config.json', (req, res) => {
res.json(appConfig);
});

0 comments on commit f86e7de

Please sign in to comment.