-
Notifications
You must be signed in to change notification settings - Fork 8.3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[Reporting] Define shims of legacy dependencies #54082
Changes from 31 commits
7315513
d954ef0
bb65245
79a9288
c931081
62dc408
78a2ea1
3e71f57
956ae17
e4761ff
48ec88c
44b714c
4192c34
4e7e448
71bd4a5
c64b4f7
ae8d134
81afb28
a6e830a
79524ef
ec3f12b
bdc87c9
80e0fcc
17b3b10
f7609d1
cb40fa3
15ab24b
37f6c3e
ddf8fac
b4dcefb
9d446a1
25e30da
5378584
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -4,16 +4,22 @@ | |
* you may not use this file except in compliance with the Elastic License. | ||
*/ | ||
|
||
export function getUserFactory(server) { | ||
return async request => { | ||
import { Legacy } from 'kibana'; | ||
import { ServerFacade } from '../../types'; | ||
|
||
export function getUserFactory(server: ServerFacade) { | ||
/* | ||
* Legacy.Request because this is called from routing middleware | ||
*/ | ||
return async (request: Legacy.Request) => { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This function takes a Legacy request because it is called from middleware. That means we get into this code before we get into any request handlers which is where we pick the properties for RequestFacade. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. @pgayvallet @restrry this means that I don't actually need to call There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. ddf8fac added that method back, but for a different usage There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Just thinking loudly: why not call this function from a route handler? NP routing doesn't provide a pre-middleware mechanism at the moment. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Hm, if that is the case it will be a major blocker for Reporting migration. @rudolf can you confirm whether we will be able to register routing middleware in the new platform? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
ATM this is not something we are planing to provide.
Correct me if I'm wrong, but the whole pre-routing mechanism can easily be replaced by some wrapper around the actual route handlers. The usage would be really close to what you currently have and should not be that big of a change Looking at your const getRouteConfig = () => {
const getOriginalRouteConfig: GetRouteConfigFactoryFn = getRouteConfigFactoryReportingPre(
server
);
const routeConfigFactory: RouteConfigFactory = getOriginalRouteConfig(
({ params: { exportType } }) => exportType
);
return {
...routeConfigFactory,
validate: {
params: Joi.object({
[...]
},
};
};
// generate report
server.route({
path: `${BASE_GENERATE}/{exportType}`,
method: 'POST',
options: getRouteConfig(),
handler: async (legacyRequest: Legacy.Request, h: ReportingResponseToolkit) => {
[...]
return response;
},
}); would become something like (also adapted to NP router format) const getRouteConfig = () => {
const getOriginalRouteConfig: GetRouteConfigFactoryFn = getRouteConfigFactoryReportingPre(
server
);
const routeConfigFactory: RouteConfigFactory = getOriginalRouteConfig(
({ params: { exportType } }) => exportType
);
return {
...routeConfigFactory,
validate: {
params: schema.object({
[...]
},
};
};
const routeConfig = getRouteConfig()
router.post(
{
path: `${BASE_GENERATE}/{exportType}`,
options: routeConfig.options
validate: routeConfig.validate,
},
routeConfig.performPreAuth(async (ctx, req, res, preAuthResult) => {
const request = makeRequestFacade(legacyRequest, preAuthResults);
....
})
); The Please ping me if you want me to go a little more in-details with that. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I'm ++ on any solution that will allow us to move further, and I don't see any problems with your proposals. I think there are a lot of ways to achieve the goal that the code is doing and pre-routing is just one of them. |
||
if (!server.plugins.security) { | ||
return null; | ||
} | ||
|
||
try { | ||
return await server.plugins.security.getUser(request); | ||
} catch (err) { | ||
server.log(['reporting', 'getUser', 'debug'], err); | ||
server.log(['reporting', 'getUser', 'error'], err); | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Nice catch here. |
||
return null; | ||
} | ||
}; | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -27,10 +27,6 @@ export function oncePerServer(fn: ServerFn) { | |
throw new TypeError('This function expects to be called with a single argument'); | ||
} | ||
|
||
if (!server || typeof server.expose !== 'function') { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Yesssss |
||
throw new TypeError('This function expects to be passed the server'); | ||
} | ||
|
||
// @ts-ignore | ||
return fn.call(this, server); | ||
}); | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -4,16 +4,18 @@ | |
* you may not use this file except in compliance with the Elastic License. | ||
*/ | ||
|
||
import { Legacy } from 'kibana'; | ||
import boom from 'boom'; | ||
import Joi from 'joi'; | ||
import rison from 'rison-node'; | ||
import { API_BASE_URL } from '../../common/constants'; | ||
import { ServerFacade, RequestFacade, ReportingResponseToolkit } from '../../types'; | ||
import { ServerFacade, ReportingResponseToolkit } from '../../types'; | ||
import { | ||
getRouteConfigFactoryReportingPre, | ||
GetRouteConfigFactoryFn, | ||
RouteConfigFactory, | ||
} from './lib/route_config_factories'; | ||
import { makeRequestFacade } from './lib/make_request_facade'; | ||
import { HandlerErrorFunction, HandlerFunction } from './types'; | ||
|
||
const BASE_GENERATE = `${API_BASE_URL}/generate`; | ||
|
@@ -54,7 +56,8 @@ export function registerGenerateFromJobParams( | |
path: `${BASE_GENERATE}/{exportType}`, | ||
method: 'POST', | ||
options: getRouteConfig(), | ||
handler: async (request: RequestFacade, h: ReportingResponseToolkit) => { | ||
handler: async (originalRequest: Legacy.Request, h: ReportingResponseToolkit) => { | ||
const request = makeRequestFacade(originalRequest); | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Do we want to keep with the |
||
let jobParamsRison: string | null; | ||
|
||
if (request.payload) { | ||
|
@@ -80,7 +83,7 @@ export function registerGenerateFromJobParams( | |
if (!jobParams) { | ||
throw new Error('missing jobParams!'); | ||
} | ||
response = await handler(exportType, jobParams, request, h); | ||
response = await handler(exportType, jobParams, originalRequest, h); | ||
} catch (err) { | ||
throw boom.badRequest(`invalid rison: ${jobParamsRison}`); | ||
} | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
moved the
ts-ignore
to reporting/index.ts