Merge branch 'master' into feat/feed
This commit is contained in:
commit
10a0d10c24
4 changed files with 78 additions and 32 deletions
3
.dockerignore
Normal file
3
.dockerignore
Normal file
|
|
@ -0,0 +1,3 @@
|
||||||
|
**/.git
|
||||||
|
**/node_modules
|
||||||
|
**/radata
|
||||||
29
Dockerfile
Normal file
29
Dockerfile
Normal file
|
|
@ -0,0 +1,29 @@
|
||||||
|
FROM node:12.18.0-alpine3.9
|
||||||
|
|
||||||
|
WORKDIR /usr/src/app
|
||||||
|
|
||||||
|
|
||||||
|
ADD ./package.json /usr/src/app/package.json
|
||||||
|
ADD ./yarn.lock /usr/src/app/yarn.lock
|
||||||
|
#RUN useradd app && \
|
||||||
|
# mkdir -p /home/app/.lnd
|
||||||
|
RUN apk update && apk upgrade && \
|
||||||
|
apk add --no-cache bash git openssh
|
||||||
|
RUN yarn install
|
||||||
|
|
||||||
|
ADD . /usr/src/app
|
||||||
|
RUN ls /usr/src/app
|
||||||
|
|
||||||
|
RUN chmod +x ./docker-start.sh
|
||||||
|
#ADD ./tls.cert /usr/src/app/tls.cert
|
||||||
|
#ADD ./admin.macaroon /usr/src/app/admin.macaroon
|
||||||
|
|
||||||
|
# && \
|
||||||
|
# chown -R app:app /home/app && \
|
||||||
|
# chown -R app:app /usr/src/app && \
|
||||||
|
# chown -R app:app /start.sh
|
||||||
|
|
||||||
|
#ARG lnd_address
|
||||||
|
#ENV LND_ADDR=$lnd_address
|
||||||
|
EXPOSE 9835
|
||||||
|
CMD ["./docker-start.sh"]
|
||||||
5
docker-start.sh
Normal file
5
docker-start.sh
Normal file
|
|
@ -0,0 +1,5 @@
|
||||||
|
#!/bin/ash
|
||||||
|
node main -h 0.0.0.0 \
|
||||||
|
-m admin.macaroon \
|
||||||
|
-d tls.cert \
|
||||||
|
-l $LND_ADDR
|
||||||
|
|
@ -1,6 +1,11 @@
|
||||||
|
/**
|
||||||
|
* @format
|
||||||
|
*/
|
||||||
const Common = require('shock-common')
|
const Common = require('shock-common')
|
||||||
const Logger = require('winston')
|
const Logger = require('winston')
|
||||||
|
const size = require('lodash/size')
|
||||||
|
|
||||||
|
const Utils = require('../utils')
|
||||||
const Key = require('../key')
|
const Key = require('../key')
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
@ -8,43 +13,47 @@ const Key = require('../key')
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* @throws {TypeError}
|
||||||
* @returns {Promise<Record<string, Common.Schema.Follow>>}
|
* @returns {Promise<Record<string, Common.Schema.Follow>>}
|
||||||
*/
|
*/
|
||||||
exports.currentFollows = () => {
|
exports.currentFollows = async () => {
|
||||||
const user = require('../../Mediator').getUser()
|
/**
|
||||||
|
* @type {Record<string, Common.Schema.Follow>}
|
||||||
return new Promise(res => {
|
*/
|
||||||
user.get(Key.FOLLOWS).load(data => {
|
const raw = await Utils.tryAndWait(
|
||||||
if (typeof data !== 'object' || data === null) {
|
// @ts-ignore
|
||||||
Logger.warn(
|
(_, user) => new Promise(res => user.get(Key.FOLLOWS).load(res)),
|
||||||
`GunDb -> getters -> currentFollows() -> Current follows data as fetched from gun is not an object but ${typeof data}. This can happen if Gun lost its cache and it's still retrieving data from the network.`
|
v => {
|
||||||
)
|
if (typeof v !== 'object' || v === null) {
|
||||||
res({})
|
return true
|
||||||
return
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const rejected = Object.entries(data).filter(
|
if (size(v) === 0) {
|
||||||
([_, follow]) => !Common.Schema.isFollow(follow)
|
return true
|
||||||
)
|
}
|
||||||
|
|
||||||
rejected.forEach(([key, item]) => {
|
return false
|
||||||
// expected when unfollowed
|
}
|
||||||
if (item !== null) {
|
)
|
||||||
Logger.warn(
|
|
||||||
`GunDb -> getters -> currentFollows() -> Item not conforming to schema found inside follows data. Key: ${key}, item: ${JSON.stringify(
|
|
||||||
item
|
|
||||||
)}.`
|
|
||||||
)
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
|
||||||
const passed = Object.entries(data).filter(([_, follow]) =>
|
if (typeof raw !== 'object' || raw === null) {
|
||||||
Common.Schema.isFollow(follow)
|
Logger.error(
|
||||||
)
|
`Expected user.follows to be an object but instead got: ${JSON.stringify(
|
||||||
|
raw
|
||||||
|
)}`
|
||||||
|
)
|
||||||
|
throw new TypeError('Could not get follows, not an object')
|
||||||
|
}
|
||||||
|
|
||||||
const p = /** @type {unknown} */ (passed)
|
const clean = {
|
||||||
|
...raw
|
||||||
|
}
|
||||||
|
|
||||||
res(/** @type {Record<string, Follow>} */ (p))
|
for (const [key, followOrNull] of Object.entries(clean)) {
|
||||||
})
|
if (!Common.Schema.isFollow(followOrNull)) {
|
||||||
})
|
delete clean[key]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return clean
|
||||||
}
|
}
|
||||||
Loading…
Add table
Add a link
Reference in a new issue