Skip to content
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

[7.x] Migrate authentication subsystem to the new platform. (#39446) #41593

Merged
merged 3 commits into from
Jul 22, 2019

Conversation

azasypkin
Copy link
Member

Backports the following commits to 7.x:

* Temporary Core workarounds.

* Move files to NP Security Plugin.

* Fix references.

* Migrate to the New Platform.

* Review#1: remove unused `loginAttempt` from provider iterator, rely more on RecursiveReadonly, etc.

* Integrate latest core changes: isTlsEnabled and get rid of legacy ES config.

* Revert `deepFreeze` changes and rely on `src/core/utils`.

* Review#2: do not mutate injectedVars in onInit. Integrate latest upstream changes.

* Use mocks provided by the Core.

* Expect ElasticsearchError instead of Boom errors as 401 Cluster client errors.

* Simplify session handling for `login`.

* Review#3: properly handle session updates for `login`, remove redundant hapi-auth-cookie deps from x-pack package.json, migrate to new core sessionStorage API, integrate latest Kerberos provider changes from upstream

* Do not clear session on login if it does not exist.
encryptionKey: Joi.any().description('This key is handled in the new platform security plugin ONLY'),
sessionTimeout: Joi.any().description('This key is handled in the new platform security plugin ONLY'),
secureCookies: Joi.any().description('This key is handled in the new platform security plugin ONLY'),
public: Joi.any().description('This key is handled in the new platform security plugin ONLY'),
Copy link
Member Author

@azasypkin azasypkin Jul 19, 2019

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

note: diff#1: keeping public in 7.x


const config = server.config();
const xpackMainPlugin = server.plugins.xpack_main;
const xpackInfo = xpackMainPlugin.info;
securityPlugin.registerLegacyAPI({
xpackInfo,
serverConfig: {
Copy link
Member Author

@azasypkin azasypkin Jul 19, 2019

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

note: diff#3: need to pass server config that's not available for NP plugins (we could ask platform team to expose it, but we don't need these in master yet, so chose to shim it),

oidc: providerOptionsSchema('oidc', Joi.object({ realm: Joi.string().required() }).required()),
saml: providerOptionsSchema('saml', Joi.object({ realm: Joi.string() })),
}).default()
authc: Joi.any().description('This key is handled in the new platform security plugin ONLY')
}).default();
},

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

note: diff#2: had to keep deprecations untouched since NP doesn't support this functionality yet, and fortunately we don't need it in master yet.

clusterClient: PublicMethodsOf<ClusterClient>;
sessionStorageFactory: SessionStorageFactory<ProviderSession>;
isSystemAPIRequest: (request: KibanaRequest) => boolean;
getServerBaseURL: () => string;
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

note: diff#4: instead of passing protocol/hostname/port tripple I just pass a function that generates server base URL. It's required since we get necessary info from the legacy plugin and it's actually shows the intention better.

});
});

describe('getServerBaseURL()', () => {
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

note: diff#5: added few tests to cover this new (well, old, since we don't need it in master anymore) function

* Retrieves server protocol name/host name/port and merges it with `xpack.security.public` config
* to construct a server base URL (deprecated, used by the SAML provider only).
*/
const getServerBaseURL = () => {
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

note: diff#6: same note as for diff#5.

basePath.get.mockReturnValue('/base-path');

return {
getServerBaseURL: () => 'test-protocol://test-hostname:1234',
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

note: diff#7: mock to cover this new function.

@@ -0,0 +1,1010 @@
/*
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

note: diff#7: removed test that checks that provider throws if realm isn't provided (it's optional in 7.x) and migrated tests that verify acs we pass in prepare and invalidate.

*/
private debug(message: string) {
this.options.log(['debug', 'security', 'saml'], message);
private getACS(request: KibanaRequest) {
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

note: diff#8: migrated this function to use getServerBaseURL.

describe('config schema', () => {
it('generates proper defaults', () => {
expect(ConfigSchema.validate({})).toMatchInlineSnapshot(`
Object {
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

note: diff#9: have no idea why eslint formats inline snapshots in 7.x in a such weird way 😞 But it what it does automatically 🤷‍♂️

);
});

describe('public', () => {
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

note: diff#10: added suite to test public.

@spalger
Copy link
Contributor

spalger commented Jul 19, 2019

retest

expect(loggingServiceMock.collect(contextMock.logger).warn).toEqual([]);
});

it('should set authProviders to authc.providers', async () => {
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

note: diff#11: added test for the "rename deprecation transformation" ugly hacky workaround I had to add in this backport (see below).

}),
// This property is deprecated, but we include it here since new platform doesn't support config deprecation
// transformations yet (e.g. `rename`), so we handle it manually for now.
authProviders: schema.maybe(schema.arrayOf(schema.string(), { minSize: 1 })),
Copy link
Member Author

@azasypkin azasypkin Jul 19, 2019

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

note: diff#12: that's the hack, I didn't find a better way to handle this "rename" deprecation use case with the primitives core provides currently. The config deprecations in NP are on the short-term Mikhail's roadmap, but we're not there yet. Let me know if you have a better idea or just don't want to see this hack at all :)

...config.authc,
// If deprecated `authProviders` is specified that most likely means that `authc.providers` isn't, but if it's
// specified then this case should be caught by the config deprecation subsystem in the legacy platform.
providers: config.authProviders || config.authc.providers,
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

note: diff#13: continuation of the hack from diff#12.

*/
export interface LegacyAPI {
xpackInfo: Pick<XPackInfo, 'isAvailable' | 'feature'>;
serverConfig: { protocol: string; hostname: string; port: number };
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

note: diff#14: declared one more property we expect from the legacy plugin

@azasypkin
Copy link
Member Author

Hey @kobelb, I had to make a number of changes in this backport that I'm not super happy about, but couldn't find a better way. I've outlined all of them in the comments (14 diffs). Let me know how you feel about them!

@azasypkin azasypkin requested a review from kobelb July 19, 2019 17:55
@elasticmachine
Copy link
Contributor

💚 Build Succeeded

@elasticmachine
Copy link
Contributor

💚 Build Succeeded

@azasypkin
Copy link
Member Author

@kobelb I've just realized you're OOO for a couple of next days, I'll go ahead and merge this PR to make it easier to backport upcoming changes, but feel free to raise any concerns you have regarding the additional changes I had to make in the backport once you're back - I'll handle them.

@azasypkin azasypkin merged commit e19a03b into elastic:7.x Jul 22, 2019
@azasypkin azasypkin deleted the backport/7.x/pr-39446 branch July 22, 2019 08:47
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants