mirror of
https://github.com/seejohnrun/haste-server.git
synced 2024-11-01 11:31:22 +00:00
add prettier
This commit is contained in:
parent
21aa23dd28
commit
a5b0a98b3f
19 changed files with 94 additions and 92 deletions
|
@ -80,6 +80,7 @@
|
||||||
"dev": "nodemon src/server.ts",
|
"dev": "nodemon src/server.ts",
|
||||||
"start": "node dist/src/server.js",
|
"start": "node dist/src/server.js",
|
||||||
"lint": "eslint src --fix",
|
"lint": "eslint src --fix",
|
||||||
"types:check": "tsc --noEmit --pretty"
|
"types:check": "tsc --noEmit --pretty",
|
||||||
|
"pretty": "prettier --write src"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
const DEFAULT_KEY_LENGTH = 10
|
const DEFAULT_KEY_LENGTH = 10
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
DEFAULT_KEY_LENGTH,
|
DEFAULT_KEY_LENGTH
|
||||||
}
|
}
|
||||||
|
|
9
src/global.d.ts
vendored
9
src/global.d.ts
vendored
|
@ -30,11 +30,11 @@ declare module 'rethinkdbdash' {
|
||||||
|
|
||||||
declare module 'connect-ratelimit' {
|
declare module 'connect-ratelimit' {
|
||||||
function connectRateLimit(
|
function connectRateLimit(
|
||||||
as: RateLimits,
|
as: RateLimits
|
||||||
): (
|
): (
|
||||||
req: express.Request,
|
req: express.Request,
|
||||||
res: express.Response,
|
res: express.Response,
|
||||||
next: express.NextFunction,
|
next: express.NextFunction
|
||||||
) => void
|
) => void
|
||||||
|
|
||||||
export = connectRateLimit
|
export = connectRateLimit
|
||||||
|
@ -47,11 +47,10 @@ declare namespace Express {
|
||||||
}
|
}
|
||||||
|
|
||||||
declare module 'st' {
|
declare module 'st' {
|
||||||
|
|
||||||
type ConnectSt = {
|
type ConnectSt = {
|
||||||
path: string
|
path: string
|
||||||
content: { maxAge : number }
|
content: { maxAge: number }
|
||||||
passthrough? : boolean
|
passthrough?: boolean
|
||||||
index: boolean | string
|
index: boolean | string
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
import buildGenerator from 'src/lib/key-generators/builder'
|
import buildGenerator from 'src/lib/key-generators/builder'
|
||||||
import type { Config } from 'src/types/config'
|
import type { Config } from 'src/types/config'
|
||||||
import buildStore from 'src/lib/document-stores/builder'
|
import buildStore from 'src/lib/document-stores/builder'
|
||||||
import DocumentHandler from "./index"
|
import DocumentHandler from './index'
|
||||||
|
|
||||||
const build = async (config: Config) => {
|
const build = async (config: Config) => {
|
||||||
const storage = await buildStore(config)
|
const storage = await buildStore(config)
|
||||||
|
@ -12,7 +12,7 @@ const build = async (config: Config) => {
|
||||||
config,
|
config,
|
||||||
maxLength: config.maxLength,
|
maxLength: config.maxLength,
|
||||||
keyLength: config.keyLength,
|
keyLength: config.keyLength,
|
||||||
keyGenerator,
|
keyGenerator
|
||||||
})
|
})
|
||||||
|
|
||||||
return documentHandler
|
return documentHandler
|
||||||
|
|
|
@ -51,7 +51,7 @@ class DocumentHandler {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
skipExpire,
|
skipExpire
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -68,7 +68,7 @@ class DocumentHandler {
|
||||||
winston.warn('document >maxLength', { maxLength: this.maxLength })
|
winston.warn('document >maxLength', { maxLength: this.maxLength })
|
||||||
response.writeHead(400, { 'content-type': 'application/json' })
|
response.writeHead(400, { 'content-type': 'application/json' })
|
||||||
response.end(
|
response.end(
|
||||||
JSON.stringify({ message: 'Document exceeds maximum length.' }),
|
JSON.stringify({ message: 'Document exceeds maximum length.' })
|
||||||
)
|
)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
@ -131,7 +131,7 @@ class DocumentHandler {
|
||||||
if (ret) {
|
if (ret) {
|
||||||
winston.verbose('retrieved raw document', { key })
|
winston.verbose('retrieved raw document', { key })
|
||||||
response.writeHead(200, {
|
response.writeHead(200, {
|
||||||
'content-type': 'text/plain; charset=UTF-8',
|
'content-type': 'text/plain; charset=UTF-8'
|
||||||
})
|
})
|
||||||
if (request.method === 'HEAD') {
|
if (request.method === 'HEAD') {
|
||||||
response.end()
|
response.end()
|
||||||
|
@ -148,7 +148,7 @@ class DocumentHandler {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
skipExpire,
|
skipExpire
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -166,7 +166,7 @@ class DocumentHandler {
|
||||||
callback(key)
|
callback(key)
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
true,
|
true
|
||||||
) // Don't bump expirations when key searching
|
) // Don't bump expirations when key searching
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -22,7 +22,7 @@ class AmazonS3DocumentStore implements Store {
|
||||||
get = (
|
get = (
|
||||||
key: string,
|
key: string,
|
||||||
callback: Callback,
|
callback: Callback,
|
||||||
skipExpire?: boolean | undefined,
|
skipExpire?: boolean | undefined
|
||||||
): void => {
|
): void => {
|
||||||
if (!this.bucket) {
|
if (!this.bucket) {
|
||||||
callback(false)
|
callback(false)
|
||||||
|
@ -31,7 +31,7 @@ class AmazonS3DocumentStore implements Store {
|
||||||
|
|
||||||
const req = {
|
const req = {
|
||||||
Bucket: this.bucket,
|
Bucket: this.bucket,
|
||||||
Key: key,
|
Key: key
|
||||||
}
|
}
|
||||||
|
|
||||||
this.client.getObject(req, (err, data) => {
|
this.client.getObject(req, (err, data) => {
|
||||||
|
@ -50,7 +50,7 @@ class AmazonS3DocumentStore implements Store {
|
||||||
key: string,
|
key: string,
|
||||||
data: string,
|
data: string,
|
||||||
callback: Callback,
|
callback: Callback,
|
||||||
skipExpire?: boolean | undefined,
|
skipExpire?: boolean | undefined
|
||||||
): void => {
|
): void => {
|
||||||
if (!this.bucket) {
|
if (!this.bucket) {
|
||||||
callback(false)
|
callback(false)
|
||||||
|
@ -61,7 +61,7 @@ class AmazonS3DocumentStore implements Store {
|
||||||
Bucket: this.bucket,
|
Bucket: this.bucket,
|
||||||
Key: key,
|
Key: key,
|
||||||
Body: data as AWS.S3.PutObjectOutput,
|
Body: data as AWS.S3.PutObjectOutput,
|
||||||
ContentType: 'text/plain',
|
ContentType: 'text/plain'
|
||||||
}
|
}
|
||||||
|
|
||||||
this.client.putObject(req, err => {
|
this.client.putObject(req, err => {
|
||||||
|
|
|
@ -33,7 +33,7 @@ class FileDocumentStore implements Store {
|
||||||
get = (
|
get = (
|
||||||
key: string,
|
key: string,
|
||||||
callback: Callback,
|
callback: Callback,
|
||||||
skipExpire?: boolean | undefined,
|
skipExpire?: boolean | undefined
|
||||||
): void => {
|
): void => {
|
||||||
const fn = `${this.basePath}/${md5(key)}`
|
const fn = `${this.basePath}/${md5(key)}`
|
||||||
fs.readFile(fn, 'utf8', (err, data) => {
|
fs.readFile(fn, 'utf8', (err, data) => {
|
||||||
|
@ -54,7 +54,7 @@ class FileDocumentStore implements Store {
|
||||||
key: string,
|
key: string,
|
||||||
data: string,
|
data: string,
|
||||||
callback: Callback,
|
callback: Callback,
|
||||||
skipExpire?: boolean | undefined,
|
skipExpire?: boolean | undefined
|
||||||
): void => {
|
): void => {
|
||||||
try {
|
try {
|
||||||
fs.mkdir(this.basePath, '700', () => {
|
fs.mkdir(this.basePath, '700', () => {
|
||||||
|
|
|
@ -26,7 +26,7 @@ class GoogleDatastoreDocumentStore implements Store {
|
||||||
key: PathType,
|
key: PathType,
|
||||||
data: string,
|
data: string,
|
||||||
callback: Callback,
|
callback: Callback,
|
||||||
skipExpire?: boolean,
|
skipExpire?: boolean
|
||||||
) => {
|
) => {
|
||||||
const expireTime =
|
const expireTime =
|
||||||
skipExpire || this.expire === undefined
|
skipExpire || this.expire === undefined
|
||||||
|
@ -40,13 +40,13 @@ class GoogleDatastoreDocumentStore implements Store {
|
||||||
{
|
{
|
||||||
name: 'value',
|
name: 'value',
|
||||||
value: data,
|
value: data,
|
||||||
excludeFromIndexes: true,
|
excludeFromIndexes: true
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
name: 'expiration',
|
name: 'expiration',
|
||||||
value: expireTime,
|
value: expireTime
|
||||||
},
|
}
|
||||||
],
|
]
|
||||||
}
|
}
|
||||||
|
|
||||||
this.datastore
|
this.datastore
|
||||||
|
@ -72,7 +72,7 @@ class GoogleDatastoreDocumentStore implements Store {
|
||||||
winston.info('document expired', {
|
winston.info('document expired', {
|
||||||
key,
|
key,
|
||||||
expiration: entity[0].expiration,
|
expiration: entity[0].expiration,
|
||||||
check: new Date(),
|
check: new Date()
|
||||||
})
|
})
|
||||||
callback(false)
|
callback(false)
|
||||||
} else {
|
} else {
|
||||||
|
@ -83,15 +83,15 @@ class GoogleDatastoreDocumentStore implements Store {
|
||||||
{
|
{
|
||||||
name: 'value',
|
name: 'value',
|
||||||
value: entity[0].value,
|
value: entity[0].value,
|
||||||
excludeFromIndexes: true,
|
excludeFromIndexes: true
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
name: 'expiration',
|
name: 'expiration',
|
||||||
value: new Date(
|
value: new Date(
|
||||||
Date.now() + (this.expire ? this.expire * 1000 : 0),
|
Date.now() + (this.expire ? this.expire * 1000 : 0)
|
||||||
),
|
)
|
||||||
},
|
}
|
||||||
],
|
]
|
||||||
}
|
}
|
||||||
this.datastore
|
this.datastore
|
||||||
.update(task)
|
.update(task)
|
||||||
|
@ -104,7 +104,7 @@ class GoogleDatastoreDocumentStore implements Store {
|
||||||
})
|
})
|
||||||
.catch(err => {
|
.catch(err => {
|
||||||
winston.error('Error retrieving value from Google Datastore', {
|
winston.error('Error retrieving value from Google Datastore', {
|
||||||
error: err,
|
error: err
|
||||||
})
|
})
|
||||||
callback(false)
|
callback(false)
|
||||||
})
|
})
|
||||||
|
|
|
@ -36,7 +36,7 @@ class MemcachedDocumentStore implements Store {
|
||||||
get = (
|
get = (
|
||||||
key: string,
|
key: string,
|
||||||
callback: Callback,
|
callback: Callback,
|
||||||
skipExpire?: boolean | undefined,
|
skipExpire?: boolean | undefined
|
||||||
): void => {
|
): void => {
|
||||||
this.client?.get(key, (error, data: string) => {
|
this.client?.get(key, (error, data: string) => {
|
||||||
const value = error ? false : data
|
const value = error ? false : data
|
||||||
|
@ -53,7 +53,7 @@ class MemcachedDocumentStore implements Store {
|
||||||
winston.error('failed to update expiration on GET', { key })
|
winston.error('failed to update expiration on GET', { key })
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
skipExpire,
|
skipExpire
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
@ -64,7 +64,7 @@ class MemcachedDocumentStore implements Store {
|
||||||
key: string,
|
key: string,
|
||||||
data: string,
|
data: string,
|
||||||
callback: Callback,
|
callback: Callback,
|
||||||
skipExpire?: boolean | undefined,
|
skipExpire?: boolean | undefined
|
||||||
): void => {
|
): void => {
|
||||||
this.client?.set(key, data, skipExpire ? 0 : this.expire || 0, error => {
|
this.client?.set(key, data, skipExpire ? 0 : this.expire || 0, error => {
|
||||||
callback(!error)
|
callback(!error)
|
||||||
|
|
|
@ -33,7 +33,7 @@ class MongoDocumentStore implements Store {
|
||||||
get = (
|
get = (
|
||||||
key: string,
|
key: string,
|
||||||
callback: Callback,
|
callback: Callback,
|
||||||
skipExpire?: boolean | undefined,
|
skipExpire?: boolean | undefined
|
||||||
): void => {
|
): void => {
|
||||||
const now = Math.floor(new Date().getTime() / 1000)
|
const now = Math.floor(new Date().getTime() / 1000)
|
||||||
|
|
||||||
|
@ -46,7 +46,7 @@ class MongoDocumentStore implements Store {
|
||||||
.findOne(
|
.findOne(
|
||||||
{
|
{
|
||||||
entry_id: key,
|
entry_id: key,
|
||||||
$or: [{ expiration: -1 }, { expiration: { $gt: now } }],
|
$or: [{ expiration: -1 }, { expiration: { $gt: now } }]
|
||||||
},
|
},
|
||||||
(error?: Error, entry?) => {
|
(error?: Error, entry?) => {
|
||||||
if (error) {
|
if (error) {
|
||||||
|
@ -67,20 +67,20 @@ class MongoDocumentStore implements Store {
|
||||||
.collection('entries')
|
.collection('entries')
|
||||||
.update(
|
.update(
|
||||||
{
|
{
|
||||||
entry_id: key,
|
entry_id: key
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
$set: {
|
$set: {
|
||||||
expiration: this.expire + now,
|
expiration: this.expire + now
|
||||||
},
|
}
|
||||||
},
|
},
|
||||||
{},
|
{},
|
||||||
() => {},
|
() => {}
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
return true
|
return true
|
||||||
},
|
}
|
||||||
)
|
)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
@ -89,7 +89,7 @@ class MongoDocumentStore implements Store {
|
||||||
key: string,
|
key: string,
|
||||||
data: string,
|
data: string,
|
||||||
callback: Callback,
|
callback: Callback,
|
||||||
skipExpire?: boolean | undefined,
|
skipExpire?: boolean | undefined
|
||||||
): void => {
|
): void => {
|
||||||
const now = Math.floor(new Date().getTime() / 1000)
|
const now = Math.floor(new Date().getTime() / 1000)
|
||||||
|
|
||||||
|
@ -102,15 +102,15 @@ class MongoDocumentStore implements Store {
|
||||||
.update(
|
.update(
|
||||||
{
|
{
|
||||||
entry_id: key,
|
entry_id: key,
|
||||||
$or: [{ expiration: -1 }, { expiration: { $gt: now } }],
|
$or: [{ expiration: -1 }, { expiration: { $gt: now } }]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
entry_id: key,
|
entry_id: key,
|
||||||
value: data,
|
value: data,
|
||||||
expiration: this.expire && !skipExpire ? this.expire + now : -1,
|
expiration: this.expire && !skipExpire ? this.expire + now : -1
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
upsert: true,
|
upsert: true
|
||||||
},
|
},
|
||||||
(error?: Error) => {
|
(error?: Error) => {
|
||||||
if (error) {
|
if (error) {
|
||||||
|
@ -119,7 +119,7 @@ class MongoDocumentStore implements Store {
|
||||||
}
|
}
|
||||||
|
|
||||||
return callback(true)
|
return callback(true)
|
||||||
},
|
}
|
||||||
)
|
)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,7 +7,7 @@ import type { PostgresStoreConfig } from 'src/types/config'
|
||||||
type ConnectCallback = (
|
type ConnectCallback = (
|
||||||
error?: Error,
|
error?: Error,
|
||||||
client?: PoolClient,
|
client?: PoolClient,
|
||||||
done?: () => void,
|
done?: () => void
|
||||||
) => void
|
) => void
|
||||||
|
|
||||||
// A postgres document store
|
// A postgres document store
|
||||||
|
@ -42,7 +42,7 @@ class PostgresDocumentStore implements Store {
|
||||||
get = (
|
get = (
|
||||||
key: string,
|
key: string,
|
||||||
callback: Callback,
|
callback: Callback,
|
||||||
skipExpire?: boolean | undefined,
|
skipExpire?: boolean | undefined
|
||||||
): void => {
|
): void => {
|
||||||
const now = Math.floor(new Date().getTime() / 1000)
|
const now = Math.floor(new Date().getTime() / 1000)
|
||||||
this.safeConnect((err, client, done): void => {
|
this.safeConnect((err, client, done): void => {
|
||||||
|
@ -56,7 +56,7 @@ class PostgresDocumentStore implements Store {
|
||||||
(error: Error, result) => {
|
(error: Error, result) => {
|
||||||
if (error) {
|
if (error) {
|
||||||
winston.error('error retrieving value from postgres', {
|
winston.error('error retrieving value from postgres', {
|
||||||
error,
|
error
|
||||||
})
|
})
|
||||||
return callback(false)
|
return callback(false)
|
||||||
}
|
}
|
||||||
|
@ -71,12 +71,12 @@ class PostgresDocumentStore implements Store {
|
||||||
}
|
}
|
||||||
|
|
||||||
return callback(false)
|
return callback(false)
|
||||||
},
|
}
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
return done?.()
|
return done?.()
|
||||||
},
|
}
|
||||||
)
|
)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
@ -86,7 +86,7 @@ class PostgresDocumentStore implements Store {
|
||||||
key: string,
|
key: string,
|
||||||
data: string,
|
data: string,
|
||||||
callback: Callback,
|
callback: Callback,
|
||||||
skipExpire?: boolean | undefined,
|
skipExpire?: boolean | undefined
|
||||||
): void => {
|
): void => {
|
||||||
const now = Math.floor(new Date().getTime() / 1000)
|
const now = Math.floor(new Date().getTime() / 1000)
|
||||||
this.safeConnect((err, client, done) => {
|
this.safeConnect((err, client, done) => {
|
||||||
|
@ -103,7 +103,7 @@ class PostgresDocumentStore implements Store {
|
||||||
}
|
}
|
||||||
callback(true)
|
callback(true)
|
||||||
return done?.()
|
return done?.()
|
||||||
},
|
}
|
||||||
)
|
)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
|
@ -35,18 +35,20 @@ class RedisDocumentStore implements Store {
|
||||||
const port = options.port || 6379
|
const port = options.port || 6379
|
||||||
const index = options.db || 0
|
const index = options.db || 0
|
||||||
|
|
||||||
const connectionParameters = url ? {
|
const connectionParameters = url
|
||||||
url
|
? {
|
||||||
}: {
|
url
|
||||||
host,
|
}
|
||||||
port
|
: {
|
||||||
}
|
host,
|
||||||
|
port
|
||||||
|
}
|
||||||
|
|
||||||
const config = {
|
const config = {
|
||||||
...connectionParameters,
|
...connectionParameters,
|
||||||
database: index as number,
|
database: index as number,
|
||||||
...(options.username ? { username: options.username } : {}),
|
...(options.username ? { username: options.username } : {}),
|
||||||
...(options.password ? { username: options.username } : {}),
|
...(options.password ? { username: options.username } : {})
|
||||||
}
|
}
|
||||||
|
|
||||||
this.client = createClient(config)
|
this.client = createClient(config)
|
||||||
|
@ -63,7 +65,7 @@ class RedisDocumentStore implements Store {
|
||||||
})
|
})
|
||||||
.catch(err => {
|
.catch(err => {
|
||||||
winston.error(`error connecting to redis index ${index}`, {
|
winston.error(`error connecting to redis index ${index}`, {
|
||||||
error: err,
|
error: err
|
||||||
})
|
})
|
||||||
process.exit(1)
|
process.exit(1)
|
||||||
})
|
})
|
||||||
|
@ -86,7 +88,7 @@ class RedisDocumentStore implements Store {
|
||||||
key: string,
|
key: string,
|
||||||
data: string,
|
data: string,
|
||||||
callback: Callback,
|
callback: Callback,
|
||||||
skipExpire?: boolean | undefined,
|
skipExpire?: boolean | undefined
|
||||||
): void => {
|
): void => {
|
||||||
this.client
|
this.client
|
||||||
?.set(key, data, this.getExpire(skipExpire))
|
?.set(key, data, this.getExpire(skipExpire))
|
||||||
|
|
|
@ -22,7 +22,7 @@ class RethinkDBStore {
|
||||||
port: options.port || 28015,
|
port: options.port || 28015,
|
||||||
db: options.db || 'haste',
|
db: options.db || 'haste',
|
||||||
user: options.user || 'admin',
|
user: options.user || 'admin',
|
||||||
password: options.password || '',
|
password: options.password || ''
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -7,7 +7,7 @@ const getConfig = (): Config => {
|
||||||
const configPath =
|
const configPath =
|
||||||
process.argv.length <= 2 ? 'project-config.js' : process.argv[2]
|
process.argv.length <= 2 ? 'project-config.js' : process.argv[2]
|
||||||
const config = JSON.parse(
|
const config = JSON.parse(
|
||||||
fs.readFileSync(path.join('config', configPath), 'utf8'),
|
fs.readFileSync(path.join('config', configPath), 'utf8')
|
||||||
)
|
)
|
||||||
|
|
||||||
config.port = (process.env.PORT || config.port || 7777) as number
|
config.port = (process.env.PORT || config.port || 7777) as number
|
||||||
|
|
|
@ -4,7 +4,8 @@ import type { Config } from 'src/types/config'
|
||||||
const build = async (config: Config): Promise<KeyGenerator> => {
|
const build = async (config: Config): Promise<KeyGenerator> => {
|
||||||
const pwOptions = config.keyGenerator
|
const pwOptions = config.keyGenerator
|
||||||
pwOptions.type = pwOptions.type || 'random'
|
pwOptions.type = pwOptions.type || 'random'
|
||||||
const Generator = (await import(`../key-generators/${pwOptions.type}`)).default
|
const Generator = (await import(`../key-generators/${pwOptions.type}`))
|
||||||
|
.default
|
||||||
const keyGenerator = new Generator(pwOptions)
|
const keyGenerator = new Generator(pwOptions)
|
||||||
|
|
||||||
return keyGenerator
|
return keyGenerator
|
||||||
|
|
|
@ -11,7 +11,7 @@ import DocumentHandler from 'src/lib/document-handler'
|
||||||
import buildDocumenthandler from 'src/lib/document-handler/builder'
|
import buildDocumenthandler from 'src/lib/document-handler/builder'
|
||||||
import {
|
import {
|
||||||
getStaticDirectory,
|
getStaticDirectory,
|
||||||
getStaticItemDirectory,
|
getStaticItemDirectory
|
||||||
} from 'src/lib/helpers/directory'
|
} from 'src/lib/helpers/directory'
|
||||||
|
|
||||||
const config: Config = getConfig()
|
const config: Config = getConfig()
|
||||||
|
@ -33,17 +33,17 @@ buildDocumenthandler(config)
|
||||||
) {
|
) {
|
||||||
const dest = `${item.substring(
|
const dest = `${item.substring(
|
||||||
0,
|
0,
|
||||||
item.length - 3,
|
item.length - 3
|
||||||
)}.min${item.substring(item.length - 3)}`
|
)}.min${item.substring(item.length - 3)}`
|
||||||
const origCode = fs.readFileSync(
|
const origCode = fs.readFileSync(
|
||||||
getStaticItemDirectory(__dirname, item),
|
getStaticItemDirectory(__dirname, item),
|
||||||
'utf8',
|
'utf8'
|
||||||
)
|
)
|
||||||
|
|
||||||
fs.writeFileSync(
|
fs.writeFileSync(
|
||||||
getStaticItemDirectory(__dirname, dest),
|
getStaticItemDirectory(__dirname, dest),
|
||||||
uglify.minify(origCode).code,
|
uglify.minify(origCode).code,
|
||||||
'utf8',
|
'utf8'
|
||||||
)
|
)
|
||||||
winston.info(`compressed ${item} into ${dest}`)
|
winston.info(`compressed ${item} into ${dest}`)
|
||||||
}
|
}
|
||||||
|
@ -66,12 +66,12 @@ buildDocumenthandler(config)
|
||||||
cb => {
|
cb => {
|
||||||
winston.debug('loaded static document', { success: cb })
|
winston.debug('loaded static document', { success: cb })
|
||||||
},
|
},
|
||||||
true,
|
true
|
||||||
)
|
)
|
||||||
} else {
|
} else {
|
||||||
winston.warn('failed to load static document', {
|
winston.warn('failed to load static document', {
|
||||||
name,
|
name,
|
||||||
path: documentPath,
|
path: documentPath
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
@ -86,25 +86,25 @@ buildDocumenthandler(config)
|
||||||
|
|
||||||
// get raw documents - support getting with extension
|
// get raw documents - support getting with extension
|
||||||
app.get('/raw/:id', async (request, response) =>
|
app.get('/raw/:id', async (request, response) =>
|
||||||
documentHandler.handleRawGet(request, response),
|
documentHandler.handleRawGet(request, response)
|
||||||
)
|
)
|
||||||
|
|
||||||
app.head('/raw/:id', (request, response) =>
|
app.head('/raw/:id', (request, response) =>
|
||||||
documentHandler.handleRawGet(request, response),
|
documentHandler.handleRawGet(request, response)
|
||||||
)
|
)
|
||||||
|
|
||||||
// // add documents
|
// // add documents
|
||||||
app.post('/documents', (request, response) =>
|
app.post('/documents', (request, response) =>
|
||||||
documentHandler.handlePost(request, response),
|
documentHandler.handlePost(request, response)
|
||||||
)
|
)
|
||||||
|
|
||||||
// get documents
|
// get documents
|
||||||
app.get('/documents/:id', (request, response) =>
|
app.get('/documents/:id', (request, response) =>
|
||||||
documentHandler.handleGet(request, response),
|
documentHandler.handleGet(request, response)
|
||||||
)
|
)
|
||||||
|
|
||||||
app.head('/documents/:id', (request, response) =>
|
app.head('/documents/:id', (request, response) =>
|
||||||
documentHandler.handleGet(request, response),
|
documentHandler.handleGet(request, response)
|
||||||
)
|
)
|
||||||
|
|
||||||
// Otherwise, try to match static files
|
// Otherwise, try to match static files
|
||||||
|
@ -113,8 +113,8 @@ buildDocumenthandler(config)
|
||||||
path: getStaticDirectory(__dirname),
|
path: getStaticDirectory(__dirname),
|
||||||
content: { maxAge: config.staticMaxAge },
|
content: { maxAge: config.staticMaxAge },
|
||||||
passthrough: true,
|
passthrough: true,
|
||||||
index: false,
|
index: false
|
||||||
}),
|
})
|
||||||
)
|
)
|
||||||
|
|
||||||
// Then we can loop back - and everything else should be a token,
|
// Then we can loop back - and everything else should be a token,
|
||||||
|
@ -129,8 +129,8 @@ buildDocumenthandler(config)
|
||||||
connectSt({
|
connectSt({
|
||||||
path: getStaticDirectory(__dirname),
|
path: getStaticDirectory(__dirname),
|
||||||
content: { maxAge: config.staticMaxAge },
|
content: { maxAge: config.staticMaxAge },
|
||||||
index: 'index.html',
|
index: 'index.html'
|
||||||
}),
|
})
|
||||||
)
|
)
|
||||||
|
|
||||||
app.listen(config.port, config.host, () => {
|
app.listen(config.port, config.host, () => {
|
||||||
|
|
|
@ -78,4 +78,3 @@ export interface KeyGeneratorConfig {
|
||||||
keyspace?: string
|
keyspace?: string
|
||||||
path?: string
|
path?: string
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,11 +1,11 @@
|
||||||
export interface Logging {
|
export interface Logging {
|
||||||
level: string
|
level: string
|
||||||
type:
|
type:
|
||||||
| 'File'
|
| 'File'
|
||||||
| 'Console'
|
| 'Console'
|
||||||
| 'Loggly'
|
| 'Loggly'
|
||||||
| 'DailyRotateFile'
|
| 'DailyRotateFile'
|
||||||
| 'Http'
|
| 'Http'
|
||||||
| 'Memory'
|
| 'Memory'
|
||||||
| 'Webhook'
|
| 'Webhook'
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,6 +8,6 @@ export interface Store {
|
||||||
key: string,
|
key: string,
|
||||||
data: string,
|
data: string,
|
||||||
callback: Callback,
|
callback: Callback,
|
||||||
skipExpire?: boolean,
|
skipExpire?: boolean
|
||||||
) => void
|
) => void
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue