mirror of
https://github.com/elastic/kibana.git
synced 2025-04-25 18:27:59 -04:00
## Summary Closes https://github.com/elastic/kibana/issues/151985 - ~~This PR introduces `maxUploadSize` file kind setting, which allows to enforce upload size per file, instead of using one value for the whole file kind~~. - ~~I left the `maxSizeBytes` as-is for now, because it is actually used in two places: (1) in the Files client; (2) in HTTP routes. So, I didn't find an easy way to reuse it~~. - Allows to configure max upload size per file. - This required separation of `FileKind` interface between browser and server. And correspondingly changes to the file kind registry. ### Checklist Delete any items that are not applicable to this PR. - [x] [Unit or functional tests](https://www.elastic.co/guide/en/kibana/master/development-tests.html) were updated or added to match the most common scenarios ### For maintainers - [x] This was checked for breaking API changes and was [labeled appropriately](https://www.elastic.co/guide/en/kibana/master/contributing.html#kibana-release-notes-process) --------- Co-authored-by: kibanamachine <42973632+kibanamachine@users.noreply.github.com>
64 lines
2.1 KiB
TypeScript
64 lines
2.1 KiB
TypeScript
/*
|
|
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
|
|
* or more contributor license agreements. Licensed under the Elastic License
|
|
* 2.0 and the Server Side Public License, v 1; you may not use this file except
|
|
* in compliance with, at your election, the Elastic License 2.0 or the Server
|
|
* Side Public License, v 1.
|
|
*/
|
|
|
|
import { AppNavLinkStatus } from '@kbn/core-application-browser';
|
|
import { AppMountParameters, CoreSetup, CoreStart, Plugin } from '@kbn/core/public';
|
|
import { PLUGIN_ID, PLUGIN_NAME, exampleFileKind, MyImageMetadata } from '../common';
|
|
import { FilesExamplePluginsStart, FilesExamplePluginsSetup } from './types';
|
|
|
|
export class FilesExamplePlugin
|
|
implements Plugin<unknown, unknown, FilesExamplePluginsSetup, FilesExamplePluginsStart>
|
|
{
|
|
public setup(
|
|
core: CoreSetup<FilesExamplePluginsStart>,
|
|
{ files, developerExamples }: FilesExamplePluginsSetup
|
|
) {
|
|
files.registerFileKind({
|
|
id: exampleFileKind.id,
|
|
allowedMimeTypes: exampleFileKind.allowedMimeTypes,
|
|
});
|
|
|
|
developerExamples.register({
|
|
appId: PLUGIN_ID,
|
|
title: PLUGIN_NAME,
|
|
description: 'Example plugin for the files plugin',
|
|
});
|
|
|
|
core.application.register({
|
|
id: PLUGIN_ID,
|
|
title: PLUGIN_NAME,
|
|
navLinkStatus: AppNavLinkStatus.hidden,
|
|
async mount(params: AppMountParameters) {
|
|
// Load application bundle
|
|
const { renderApp } = await import('./application');
|
|
// Get start services as specified in kibana.json
|
|
const [coreStart, deps] = await core.getStartServices();
|
|
// Render the application
|
|
return renderApp(
|
|
coreStart,
|
|
{
|
|
files: {
|
|
unscoped: deps.files.filesClientFactory.asUnscoped<MyImageMetadata>(),
|
|
example: deps.files.filesClientFactory.asScoped<MyImageMetadata>(exampleFileKind.id),
|
|
},
|
|
},
|
|
params
|
|
);
|
|
},
|
|
});
|
|
|
|
// Return methods that should be available to other plugins
|
|
return {};
|
|
}
|
|
|
|
public start(core: CoreStart) {
|
|
return {};
|
|
}
|
|
|
|
public stop() {}
|
|
}
|