diff --git a/flow-typed/npm/compression_vx.x.x.js b/flow-typed/npm/compression_vx.x.x.js new file mode 100644 index 000000000..66182a5d3 --- /dev/null +++ b/flow-typed/npm/compression_vx.x.x.js @@ -0,0 +1,33 @@ +// flow-typed signature: 80c21b4a25778a0faefd532204b78050 +// flow-typed version: <>/compression_v1.7.2/flow_v0.67.1 + +/** + * This is an autogenerated libdef stub for: + * + * 'compression' + * + * Fill this stub out by replacing all the `any` types. + * + * Once filled out, we encourage you to share your work with the + * community by sending a pull request to: + * https://github.com/flowtype/flow-typed + */ + +declare module 'compression' { + declare module.exports: any; +} + +/** + * We include stubs for each file inside this npm package in case you need to + * require those files directly. Feel free to delete any files that aren't + * needed. + */ + + +// Filename aliases +declare module 'compression/index' { + declare module.exports: $Exports<'compression'>; +} +declare module 'compression/index.js' { + declare module.exports: $Exports<'compression'>; +} diff --git a/flow-typed/npm/cors_vx.x.x.js b/flow-typed/npm/cors_vx.x.x.js new file mode 100644 index 000000000..a061f61dc --- /dev/null +++ b/flow-typed/npm/cors_vx.x.x.js @@ -0,0 +1,88 @@ +// flow-typed signature: d369e8a6411b1ce4fcd5339b6d41e441 +// flow-typed version: <>/cors_v2.8.4/flow_v0.67.1 + +/** + * This is an autogenerated libdef stub for: + * + * 'cors' + * + * Fill this stub out by replacing all the `any` types. + * + * Once filled out, we encourage you to share your work with the + * community by sending a pull request to: + * https://github.com/flowtype/flow-typed + */ + +declare module 'cors' { + declare module.exports: any; +} + +/** + * We include stubs for each file inside this npm package in case you need to + * require those files directly. Feel free to delete any files that aren't + * needed. + */ +declare module 'cors/lib/index' { + declare module.exports: any; +} + +declare module 'cors/test/basic-auth' { + declare module.exports: any; +} + +declare module 'cors/test/body-events' { + declare module.exports: any; +} + +declare module 'cors/test/cors' { + declare module.exports: any; +} + +declare module 'cors/test/error-response' { + declare module.exports: any; +} + +declare module 'cors/test/example-app' { + declare module.exports: any; +} + +declare module 'cors/test/issue-2' { + declare module.exports: any; +} + +declare module 'cors/test/issue-31' { + declare module.exports: any; +} + +declare module 'cors/test/support/env' { + declare module.exports: any; +} + +// Filename aliases +declare module 'cors/lib/index.js' { + declare module.exports: $Exports<'cors/lib/index'>; +} +declare module 'cors/test/basic-auth.js' { + declare module.exports: $Exports<'cors/test/basic-auth'>; +} +declare module 'cors/test/body-events.js' { + declare module.exports: $Exports<'cors/test/body-events'>; +} +declare module 'cors/test/cors.js' { + declare module.exports: $Exports<'cors/test/cors'>; +} +declare module 'cors/test/error-response.js' { + declare module.exports: $Exports<'cors/test/error-response'>; +} +declare module 'cors/test/example-app.js' { + declare module.exports: $Exports<'cors/test/example-app'>; +} +declare module 'cors/test/issue-2.js' { + declare module.exports: $Exports<'cors/test/issue-2'>; +} +declare module 'cors/test/issue-31.js' { + declare module.exports: $Exports<'cors/test/issue-31'>; +} +declare module 'cors/test/support/env.js' { + declare module.exports: $Exports<'cors/test/support/env'>; +} diff --git a/flow-typed/npm/pkginfo_vx.x.x.js b/flow-typed/npm/pkginfo_vx.x.x.js new file mode 100644 index 000000000..5b5b58013 --- /dev/null +++ b/flow-typed/npm/pkginfo_vx.x.x.js @@ -0,0 +1,81 @@ +// flow-typed signature: 5ea2cb6aa83979de9573ab3e3723be3f +// flow-typed version: <>/pkginfo_v0.4.1/flow_v0.67.1 + +/** + * This is an autogenerated libdef stub for: + * + * 'pkginfo' + * + * Fill this stub out by replacing all the `any` types. + * + * Once filled out, we encourage you to share your work with the + * community by sending a pull request to: + * https://github.com/flowtype/flow-typed + */ + +declare module 'pkginfo' { + declare module.exports: any; +} + +/** + * We include stubs for each file inside this npm package in case you need to + * require those files directly. Feel free to delete any files that aren't + * needed. + */ +declare module 'pkginfo/examples/all-properties' { + declare module.exports: any; +} + +declare module 'pkginfo/examples/array-argument' { + declare module.exports: any; +} + +declare module 'pkginfo/examples/multiple-properties' { + declare module.exports: any; +} + +declare module 'pkginfo/examples/object-argument' { + declare module.exports: any; +} + +declare module 'pkginfo/examples/single-property' { + declare module.exports: any; +} + +declare module 'pkginfo/examples/target-dir' { + declare module.exports: any; +} + +declare module 'pkginfo/lib/pkginfo' { + declare module.exports: any; +} + +declare module 'pkginfo/test/pkginfo-test' { + declare module.exports: any; +} + +// Filename aliases +declare module 'pkginfo/examples/all-properties.js' { + declare module.exports: $Exports<'pkginfo/examples/all-properties'>; +} +declare module 'pkginfo/examples/array-argument.js' { + declare module.exports: $Exports<'pkginfo/examples/array-argument'>; +} +declare module 'pkginfo/examples/multiple-properties.js' { + declare module.exports: $Exports<'pkginfo/examples/multiple-properties'>; +} +declare module 'pkginfo/examples/object-argument.js' { + declare module.exports: $Exports<'pkginfo/examples/object-argument'>; +} +declare module 'pkginfo/examples/single-property.js' { + declare module.exports: $Exports<'pkginfo/examples/single-property'>; +} +declare module 'pkginfo/examples/target-dir.js' { + declare module.exports: $Exports<'pkginfo/examples/target-dir'>; +} +declare module 'pkginfo/lib/pkginfo.js' { + declare module.exports: $Exports<'pkginfo/lib/pkginfo'>; +} +declare module 'pkginfo/test/pkginfo-test.js' { + declare module.exports: $Exports<'pkginfo/test/pkginfo-test'>; +} diff --git a/package.json b/package.json index 5496d68a6..4651dc61d 100644 --- a/package.json +++ b/package.json @@ -50,7 +50,7 @@ "@commitlint/cli": "6.1.3", "@commitlint/config-conventional": "6.1.3", "@commitlint/travis-cli": "6.1.3", - "@verdaccio/types": "2.0.0", + "@verdaccio/types": "2.0.1", "axios": "0.18.0", "babel-cli": "6.26.0", "babel-core": "6.26.0", diff --git a/src/api/endpoint/index.js b/src/api/endpoint/index.js index bcbb97d69..b9af5d3fd 100644 --- a/src/api/endpoint/index.js +++ b/src/api/endpoint/index.js @@ -1,6 +1,6 @@ // @flow -import type {IAuth, IStorage} from '../../../types'; +import type {IAuth, IStorageHandler} from '../../../types'; import type {Config} from '@verdaccio/types'; import express from 'express'; @@ -15,14 +15,16 @@ import pkg from './api/package'; const {match, validate_name, validatePackage, encodeScopePackage, anti_loop} = require('../middleware'); -export default function(config: Config, auth: IAuth, storage: IStorage) { +export default function(config: Config, auth: IAuth, storage: IStorageHandler) { /* eslint new-cap:off */ const app = express.Router(); /* eslint new-cap:off */ // validate all of these params as a package name // this might be too harsh, so ask if it causes trouble + // $FlowFixMe app.param('package', validatePackage); + // $FlowFixMe app.param('filename', validate_name); app.param('tag', validate_name); app.param('version', validate_name); diff --git a/src/api/index.js b/src/api/index.js index 3fd078259..85bb59a25 100644 --- a/src/api/index.js +++ b/src/api/index.js @@ -1,3 +1,5 @@ +// @flow + import express from 'express'; import Error from 'http-errors'; import compression from 'compression'; @@ -9,18 +11,22 @@ import hookDebug from './debug'; import Auth from '../lib/auth'; import apiEndpoint from './endpoint'; -const Logger = require('../lib/logger'); +import type {$Application} from 'express'; +import type {$ResponseExtend, $RequestExtend, $NextFunctionVer, IStorageHandler, IAuth} from '../../types'; +import type {Config as IConfig} from '@verdaccio/types'; + +const LoggerApp = require('../lib/logger'); const Config = require('../lib/config'); const Middleware = require('./middleware'); const Cats = require('../lib/status-cats'); -export default function(configHash) { +export default function(configHash: any) { // Config - Logger.setup(configHash.logs); - const config = new Config(configHash); - const storage = new Storage(config); - const auth = new Auth(config); - const app = express(); + LoggerApp.setup(configHash.logs); + const config: IConfig = new Config(configHash); + const storage: IStorageHandler = new Storage(config); + const auth: IAuth = new Auth(config); + const app: $Application = express(); // run in production mode by default, just in case // it shouldn't make any difference anyway app.set('env', process.env.NODE_ENV || 'production'); @@ -29,14 +35,14 @@ export default function(configHash) { // Router setup app.use(Middleware.log); app.use(Middleware.errorReportingMiddleware); - app.use(function(req, res, next) { + app.use(function(req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer) { res.setHeader('X-Powered-By', config.user_agent); next(); }); app.use(Cats.middleware); app.use(compression()); - app.get('/favicon.ico', function(req, res, next) { + app.get('/favicon.ico', function(req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer) { req.url = '/-/static/favicon.png'; next(); }); @@ -49,7 +55,7 @@ export default function(configHash) { // register middleware plugins const plugin_params = { config: config, - logger: Logger.logger, + logger: LoggerApp.logger, }; const plugins = loadPlugin(config, config.middlewares, plugin_params, function(plugin) { return plugin.register_middlewares; @@ -66,17 +72,17 @@ export default function(configHash) { app.use('/', require('./web')(config, auth, storage)); app.use('/-/verdaccio/', require('./web/api')(config, auth, storage)); } else { - app.get('/', function(req, res, next) { + app.get('/', function(req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer) { next(Error[404]('Web interface is disabled in the config file')); }); } // Catch 404 - app.get('/*', function(req, res, next) { + app.get('/*', function(req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer) { next(Error[404]('File not found')); }); - app.use(function(err, req, res, next) { + app.use(function(err, req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer) { if (_.isError(err)) { if (err.code === 'ECONNABORT' && res.statusCode === 304) { return next(); diff --git a/src/api/middleware.js b/src/api/middleware.js index 41771ccad..e801724fb 100644 --- a/src/api/middleware.js +++ b/src/api/middleware.js @@ -1,3 +1,5 @@ +// @flow + import crypto from 'crypto'; import _ from 'lodash'; import { @@ -5,11 +7,13 @@ import { validate_package as utilValidatePackage, isObject, ErrorCode} from '../lib/utils'; +import type {$ResponseExtend, $RequestExtend, $NextFunctionVer, IAuth} from '../../types'; +import type {Config} from '@verdaccio/types'; const Logger = require('../lib/logger'); -export function match(regexp) { - return function(req, res, next, value) { +export function match(regexp: RegExp) { + return function(req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer, value: string) { if (regexp.exec(value)) { next(); } else { @@ -18,13 +22,15 @@ export function match(regexp) { }; } -export function securityIframe(req, res, next) { +export function securityIframe(req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer) { // disable loading in frames (clickjacking, etc.) res.header('X-Frame-Options', 'deny'); next(); } -export function validate_name(req, res, next, value, name) { +// flow: express does not match properly +// flow info https://github.com/flowtype/flow-typed/issues?utf8=%E2%9C%93&q=is%3Aissue+is%3Aopen+express +export function validate_name(req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer, value: string, name: string) { if (value.charAt(0) === '-') { // special case in couchdb usually next('route'); @@ -35,7 +41,9 @@ export function validate_name(req, res, next, value, name) { } } -export function validatePackage(req, res, next, value, name) { +// flow: express does not match properly +// flow info https://github.com/flowtype/flow-typed/issues?utf8=%E2%9C%93&q=is%3Aissue+is%3Aopen+express +export function validatePackage(req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer, value: string, name: string) { if (value.charAt(0) === '-') { // special case in couchdb usually next('route'); @@ -46,8 +54,8 @@ export function validatePackage(req, res, next, value, name) { } } -export function media(expect) { - return function(req, res, next) { +export function media(expect: string) { + return function(req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer) { if (req.headers['content-type'] !== expect) { next( ErrorCode.getCode(415, 'wrong content-type, expect: ' + expect + ', got: '+req.headers['content-type']) ); @@ -57,7 +65,7 @@ export function media(expect) { }; } -export function encodeScopePackage(req, res, next) { +export function encodeScopePackage(req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer) { if (req.url.indexOf('@') !== -1) { // e.g.: /@org/pkg/1.2.3 -> /@org%2Fpkg/1.2.3, /@org%2Fpkg/1.2.3 -> /@org%2Fpkg/1.2.3 req.url = req.url.replace(/^(\/@[^\/%]+)\/(?!$)/, '$1%2F'); @@ -65,15 +73,15 @@ export function encodeScopePackage(req, res, next) { next(); } -export function expect_json(req, res, next) { +export function expect_json(req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer) { if (!isObject(req.body)) { return next( ErrorCode.get400('can\'t parse incoming json') ); } next(); } -export function anti_loop(config) { - return function(req, res, next) { +export function anti_loop(config: Config) { + return function(req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer) { if (req.headers.via != null) { let arr = req.headers.via.split(','); @@ -100,15 +108,15 @@ function md5sum(data) { } -export function allow(auth) { - return function(action) { - return function(req, res, next) { +export function allow(auth: IAuth) { + return function(action: string) { + return function(req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer) { req.pause(); let packageName = req.params.package; if (req.params.scope) { packageName = `@${req.params.scope}/${packageName}`; } - + // $FlowFixMe auth['allow_' + action](packageName, req.remote_user, function(error, allowed) { req.resume(); if (error) { @@ -125,7 +133,7 @@ export function allow(auth) { }; } - export function final(body, req, res, next) { + export function final(body: any, req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer) { if (res.statusCode === 401 && !res.getHeader('WWW-Authenticate')) { // they say it's required for 401, so... res.header('WWW-Authenticate', 'Basic, Bearer'); @@ -168,7 +176,7 @@ export function allow(auth) { res.send(body); } -export function log(req, res, next) { +export function log(req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer) { // logger req.log = Logger.logger.child({sub: 'in'}); @@ -239,7 +247,7 @@ export function log(req, res, next) { }; req.on('close', function() { - log(true); + log(); }); const _end = res.end; @@ -255,7 +263,7 @@ export function log(req, res, next) { } // Middleware -export function errorReportingMiddleware(req, res, next) { +export function errorReportingMiddleware(req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer) { res.report_error = res.report_error || function(err) { if (err.status && err.status >= 400 && err.status < 600) { if (_.isNil(res.headersSent) === false) { diff --git a/src/api/web/api.js b/src/api/web/api.js index 9d6034e18..398545ca7 100644 --- a/src/api/web/api.js +++ b/src/api/web/api.js @@ -1,3 +1,5 @@ +// @flow + import {Router} from 'express'; import bodyParser from 'body-parser'; import addUserAuthApi from './endpoint/user'; @@ -6,20 +8,25 @@ import addSearchWebApi from './endpoint/search'; import Search from '../../lib/search'; import {match, validate_name, validatePackage, securityIframe} from '../middleware'; +import type {Config} from '@verdaccio/types'; +import type {IAuth, IStorageHandler} from '../../../types'; const route = Router(); /* eslint new-cap: 0 */ /* This file include all verdaccio only API(Web UI), for npm API please see ../endpoint/ */ -module.exports = function(config, auth, storage) { +module.exports = function(config: Config, auth: IAuth, storage: IStorageHandler) { Search.configureStorage(storage); // validate all of these params as a package name // this might be too harsh, so ask if it causes trouble + // $FlowFixMe route.param('package', validatePackage); + // $FlowFixMe route.param('filename', validate_name); + // $FlowFixMe route.param('version', validate_name); route.param('anything', match(/.*/)); diff --git a/src/api/web/endpoint/package.js b/src/api/web/endpoint/package.js index 973bfe77f..f77f077d2 100644 --- a/src/api/web/endpoint/package.js +++ b/src/api/web/endpoint/package.js @@ -1,14 +1,25 @@ +// @flow + import _ from 'lodash'; import {addScope, addGravatarSupport, deleteProperties, sortByName, DIST_TAGS} from '../../../lib/utils'; import {allow} from '../../middleware'; import async from 'async'; import marked from 'marked'; +import type {Router} from 'express'; +import type { + IAuth, + $ResponseExtend, + $RequestExtend, + $NextFunctionVer, + IStorageHandler, + $SidebarPackage} from '../../../../types'; -function addPackageWebApi(route, storage, auth) { + +function addPackageWebApi(route: Router, storage: IStorageHandler, auth: IAuth) { const can = allow(auth); // Get list of all visible package - route.get('/packages', function(req, res, next) { + route.get('/packages', function(req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer) { storage.getLocalDatabase(function(err, packages) { if (err) { // that function shouldn't produce any @@ -40,7 +51,8 @@ function addPackageWebApi(route, storage, auth) { }); // Get package readme - route.get('/package/readme/(@:scope/)?:package/:version?', can('access'), function(req, res, next) { + route.get('/package/readme/(@:scope/)?:package/:version?', can('access'), + function(req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer) { const packageName = req.params.scope ? addScope(req.params.scope, req.params.package) : req.params.package; storage.getPackage({ @@ -57,18 +69,21 @@ function addPackageWebApi(route, storage, auth) { }); }); - route.get('/sidebar/(@:scope/)?:package', function(req, res, next) { - const packageName = req.params.scope ? addScope(req.params.scope, req.params.package) : req.params.package; + route.get('/sidebar/(@:scope/)?:package', + function(req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer) { + const packageName: string = req.params.scope ? addScope(req.params.scope, req.params.package) : req.params.package; storage.getPackage({ name: packageName, keepUpLinkData: true, req, - callback: function(err, info) { + callback: function(err: Error, info: $SidebarPackage) { if (_.isNil(err)) { - info.latest = info.versions[info[DIST_TAGS].latest]; - info = deleteProperties(['readme', 'versions'], info); - info = addGravatarSupport(info); + const sideBarInfo: any = _.clone(info); + sideBarInfo.latest = info.versions[info[DIST_TAGS].latest]; + + info = deleteProperties(['readme', 'versions'], sideBarInfo); + info = addGravatarSupport(sideBarInfo); next(info); } else { res.status(404); diff --git a/src/api/web/endpoint/search.js b/src/api/web/endpoint/search.js index b0c21eaa8..834f9b698 100644 --- a/src/api/web/endpoint/search.js +++ b/src/api/web/endpoint/search.js @@ -1,9 +1,13 @@ +// @flow + import Search from '../../../lib/search'; import {DIST_TAGS} from '../../../lib/utils'; +import type {Router} from 'express'; +import type {IAuth, $ResponseExtend, $RequestExtend, $NextFunctionVer, IStorageHandler} from '../../../../types'; -function addSearchWebApi(route, storage, auth) { +function addSearchWebApi(route: Router, storage: IStorageHandler, auth: IAuth) { // Search package - route.get('/search/:anything', function(req, res, next) { + route.get('/search/:anything', function(req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer) { const results = Search.query(req.params.anything); const packages = []; diff --git a/src/api/web/endpoint/user.js b/src/api/web/endpoint/user.js index 9ea55e821..857d9dc3f 100644 --- a/src/api/web/endpoint/user.js +++ b/src/api/web/endpoint/user.js @@ -1,8 +1,13 @@ +// @flow + import HTTPError from 'http-errors'; +import type {Config} from '@verdaccio/types'; +import type {Router} from 'express'; +import type {IAuth, $ResponseExtend, $RequestExtend, $NextFunctionVer} from '../../../../types'; import {combineBaseUrl, getWebProtocol} from '../../../lib/utils'; -function addUserAuthApi(route, auth, config) { - route.post('/login', function(req, res, next) { +function addUserAuthApi(route: Router, auth: IAuth, config: Config) { + route.post('/login', function(req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer) { auth.authenticate(req.body.username, req.body.password, (err, user) => { if (!err) { req.remote_user = user; @@ -17,7 +22,7 @@ function addUserAuthApi(route, auth, config) { }); }); - route.post('/-/logout', function(req, res, next) { + route.post('/-/logout', function(req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer) { const base = combineBaseUrl(getWebProtocol(req), req.get('host'), config.url_prefix); res.cookies.set('token', ''); diff --git a/src/lib/bootstrap.js b/src/lib/bootstrap.js index 5e2f64287..0c14bf44d 100644 --- a/src/lib/bootstrap.js +++ b/src/lib/bootstrap.js @@ -1,13 +1,19 @@ +// @flow + import {assign, isObject, isFunction} from 'lodash'; import Path from 'path'; import URL from 'url'; import fs from 'fs'; import http from'http'; import https from 'https'; +// $FlowFixMe import constants from 'constants'; import server from '../api/index'; import {parse_address} from './utils'; +import type {Callback} from '@verdaccio/types'; +import type {$Application} from 'express'; + const logger = require('./logger'); /** @@ -21,7 +27,7 @@ const logger = require('./logger'); - localhost:5557 @return {Array} */ -export function getListListenAddresses(argListen, configListen) { +export function getListListenAddresses(argListen: string, configListen: mixed) { // command line || config file || default let addresses; if (argListen) { @@ -57,7 +63,7 @@ export function getListListenAddresses(argListen, configListen) { * @param {String} pkgVersion * @param {String} pkgName */ -function startVerdaccio(config, cliListen, configPath, pkgVersion, pkgName, callback) { +function startVerdaccio(config: any, cliListen: string, configPath: string, pkgVersion: string, pkgName: string, callback: Callback) { if (isObject(config) === false) { throw new Error('config file must be an object'); } @@ -143,7 +149,7 @@ function handleHTTPS(app, configPath, config) { } } -function listenDefaultCallback(webServer, addr, pkgName, pkgVersion) { +function listenDefaultCallback(webServer: $Application, addr: any, pkgName: string, pkgVersion: string) { webServer.listen(addr.port || addr.path, addr.host, () => { // send a message for tests if (isFunction(process.send)) { @@ -151,6 +157,7 @@ function listenDefaultCallback(webServer, addr, pkgName, pkgVersion) { verdaccio_started: true, }); } + // $FlowFixMe }).on('error', function(err) { logger.logger.fatal({err: err}, 'cannot create server: @{err.message}'); process.exit(2); diff --git a/src/lib/config-path.js b/src/lib/config-path.js index 628e60ee1..258bb8c88 100644 --- a/src/lib/config-path.js +++ b/src/lib/config-path.js @@ -1,3 +1,5 @@ +// @flow + import fs from 'fs'; import _ from 'lodash'; import Path from 'path'; @@ -16,7 +18,7 @@ const pkgJSON = require('../../package.json'); * Find and get the first config file that match. * @return {String} the config file path */ -function findConfigFile(configPath) { +function findConfigFile(configPath: any) { if (_.isNil(configPath) === false) { return Path.resolve(configPath); } @@ -27,7 +29,7 @@ function findConfigFile(configPath) { throw new Error('no configuration files can be proccesed'); } - const primaryConf = _.find(configPaths, (configLocation) => fileExists(configLocation.path)); + const primaryConf: any = _.find(configPaths, (configLocation: any) => fileExists(configLocation.path)); if (_.isNil(primaryConf) === false) { return primaryConf.path; } @@ -35,7 +37,7 @@ function findConfigFile(configPath) { return createConfigFile(_.head(configPaths)).path; } -function createConfigFile(configLocation) { +function createConfigFile(configLocation: any) { createConfigFolder(configLocation); const defaultConfig = updateStorageLinks(configLocation, readDefaultConfig()); @@ -61,6 +63,7 @@ function updateStorageLinks(configLocation, defaultConfig) { // $XDG_DATA_HOME defines the base directory relative to which user specific data files should be stored, // If $XDG_DATA_HOME is either not set or empty, a default equal to $HOME/.local/share should be used. + // $FlowFixMe let dataDir = process.env.XDG_DATA_HOME || Path.join(process.env.HOME, '.local', 'share'); if (folder_exists(dataDir)) { dataDir = Path.resolve(Path.join(dataDir, pkgJSON.name, 'storage')); diff --git a/src/lib/config.js b/src/lib/config.js index e7871db8a..6e6927419 100644 --- a/src/lib/config.js +++ b/src/lib/config.js @@ -1,6 +1,3 @@ -/* eslint prefer-rest-params: "off" */ -/* eslint prefer-spread: "off" */ - const assert = require('assert'); const _ = require('lodash'); const Error = require('http-errors'); @@ -21,6 +18,7 @@ function flatten(array) { let result = []; for (let i=0; i, packageInfo: Package) { +function deleteProperties(propertiesToDelete: Array, objectItem: any) { _.forEach(propertiesToDelete, (property) => { - delete packageInfo[property]; + delete objectItem[property]; }); - return packageInfo; + return objectItem; } -function addGravatarSupport(info: any) { - if (_.isString(_.get(info, 'latest.author.email'))) { - info.latest.author.avatar = generateGravatarUrl(info.latest.author.email); +function addGravatarSupport(pkgInfo: any) { + if (_.isString(_.get(pkgInfo, 'latest.author.email'))) { + pkgInfo.latest.author.avatar = generateGravatarUrl(pkgInfo.latest.author.email); } else { // _.get can't guarantee author property exist - _.set(info, 'latest.author.avatar', generateGravatarUrl()); + _.set(pkgInfo, 'latest.author.avatar', generateGravatarUrl()); } - if (_.get(info, 'latest.contributors.length', 0) > 0) { - info.latest.contributors = _.map(info.latest.contributors, (contributor) => { + if (_.get(pkgInfo, 'latest.contributors.length', 0) > 0) { + pkgInfo.latest.contributors = _.map(pkgInfo.latest.contributors, (contributor) => { if (_.isString(contributor.email)) { contributor.avatar = generateGravatarUrl(contributor.email); } else { @@ -428,7 +428,7 @@ function addGravatarSupport(info: any) { ); } - return info; + return pkgInfo; } export { diff --git a/types/index.js b/types/index.js index 5769c8ddd..c9ea711ba 100644 --- a/types/index.js +++ b/types/index.js @@ -23,6 +23,10 @@ export interface IAuth { plugins: Array; aes_encrypt(buf: Buffer): Buffer; basic_middleware(): $NextFunctionVer; + jwtMiddleware(): $NextFunctionVer; + authenticate(user: string, password: string, cb: Callback): void; + allow_access(packageName: string, user: string, callback: Callback): void; + issue_token(user: string, time: string): string; add_user(user: string, password: string, cb: Callback): any; } @@ -109,3 +113,4 @@ export interface IStorage { export type $RequestExtend = $Request & {remote_user?: any} export type $ResponseExtend = $Response & {cookies?: any} export type $NextFunctionVer = NextFunction & mixed; +export type $SidebarPackage = Package & {latest: mixed} diff --git a/yarn.lock b/yarn.lock index 8498e5d52..4f217e1b9 100644 --- a/yarn.lock +++ b/yarn.lock @@ -239,9 +239,9 @@ version "0.0.2" resolved "https://registry.npmjs.org/@verdaccio/streams/-/streams-0.0.2.tgz#72cd65449e657b462a1ca094f663cad9ea872427" -"@verdaccio/types@2.0.0": - version "2.0.0" - resolved "https://registry.npmjs.org/@verdaccio/types/-/types-2.0.0.tgz#fc7842dde415bb390b2d65e7b874fee48b3e3976" +"@verdaccio/types@2.0.1": + version "2.0.1" + resolved "https://registry.npmjs.org/@verdaccio/types/-/types-2.0.1.tgz#0ac6b7bee50112ce4aefe6cd0c2d5cb108e22b23" JSONStream@1.3.2, JSONStream@^1.0.4: version "1.3.2"