mirror of
https://github.com/ToolJet/ToolJet
synced 2026-04-24 06:57:40 +00:00
* added cert fields * Implemented ssl certificates feature * Fixed some errors * removed try-catch * updated the doc
95 lines
3.1 KiB
TypeScript
95 lines
3.1 KiB
TypeScript
import { ConnectionTestResult, QueryService, QueryResult, QueryError } from '@tooljet-plugins/common';
|
|
import { getDocument, updateDocument } from './operations';
|
|
import { indexDocument, search } from './operations';
|
|
import { Client, ClientOptions } from '@opensearch-project/opensearch';
|
|
import { SourceOptions, QueryOptions } from './types';
|
|
|
|
export default class ElasticsearchService implements QueryService {
|
|
async run(sourceOptions: SourceOptions, queryOptions: QueryOptions): Promise<QueryResult> {
|
|
const client = await this.getConnection(sourceOptions);
|
|
let result = {};
|
|
const operation = queryOptions.operation;
|
|
|
|
try {
|
|
switch (operation) {
|
|
case 'search':
|
|
result = await search(client, queryOptions.index, queryOptions.query);
|
|
break;
|
|
case 'index_document':
|
|
result = await indexDocument(client, queryOptions.index, queryOptions.body);
|
|
break;
|
|
case 'get':
|
|
result = await getDocument(client, queryOptions.index, queryOptions.id);
|
|
break;
|
|
case 'update':
|
|
result = await updateDocument(client, queryOptions.index, queryOptions.id, queryOptions.body);
|
|
break;
|
|
}
|
|
} catch (err) {
|
|
console.log(err);
|
|
throw new QueryError('Query could not be completed', err.message, {});
|
|
}
|
|
|
|
return {
|
|
status: 'ok',
|
|
data: result,
|
|
};
|
|
}
|
|
|
|
async testConnection(sourceOptions: SourceOptions): Promise<ConnectionTestResult> {
|
|
const client = await this.getConnection(sourceOptions);
|
|
await client.info();
|
|
|
|
return {
|
|
status: 'ok',
|
|
};
|
|
}
|
|
|
|
determineProtocol(sourceOptions: SourceOptions) {
|
|
// Scheme was hardcoded as https earlier
|
|
// Thus checking it to keep things backwards copatible
|
|
// Need a migration to fix the data for existing es datasources otherwise
|
|
const scheme = sourceOptions.scheme;
|
|
const sslEnabled = sourceOptions.ssl_enabled;
|
|
if (scheme && sslEnabled === undefined) {
|
|
return 'https';
|
|
}
|
|
return sslEnabled ? 'https' : 'http';
|
|
}
|
|
|
|
async getConnection(sourceOptions: SourceOptions): Promise<any> {
|
|
const host = sourceOptions.host;
|
|
const port = sourceOptions.port;
|
|
const username = sourceOptions.username;
|
|
const password = sourceOptions.password;
|
|
const sslEnabled = sourceOptions.ssl_enabled;
|
|
const protocol = this.determineProtocol(sourceOptions);
|
|
const sslCertificate = sourceOptions.ssl_certificate;
|
|
|
|
let url = '';
|
|
|
|
if (username || password) {
|
|
url = `${protocol}://${username}:${password}@${host}:${port}`;
|
|
} else {
|
|
url = `${protocol}://${host}:${port}`;
|
|
}
|
|
|
|
const options: ClientOptions = { node: url };
|
|
|
|
if (sslEnabled) {
|
|
if (sslCertificate === 'ca_certificate') {
|
|
options['ssl'] = {
|
|
ca: sourceOptions.ca_cert ?? undefined,
|
|
};
|
|
} else if (sslCertificate === 'client_certificate') {
|
|
options['ssl'] = {
|
|
ca: sourceOptions.root_cert ?? undefined,
|
|
cert: sourceOptions.client_cert ?? undefined,
|
|
key: sourceOptions.client_key ?? undefined,
|
|
};
|
|
}
|
|
}
|
|
|
|
return new Client(options);
|
|
}
|
|
}
|