search.js 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. // eslint-disable-next-line no-unused-vars
  2. const logger = require('@alias/logger')('growi:service:search');
  3. class SearchService {
  4. constructor(crowi) {
  5. this.crowi = crowi;
  6. this.configManager = crowi.configManager;
  7. this.isErrorOccuredOnHealthcheck = null;
  8. this.isErrorOccuredOnSearching = null;
  9. try {
  10. this.delegator = this.generateDelegator();
  11. }
  12. catch (err) {
  13. logger.error(err);
  14. }
  15. if (this.isConfigured) {
  16. this.delegator.init();
  17. this.registerUpdateEvent();
  18. }
  19. }
  20. get isConfigured() {
  21. return this.delegator != null;
  22. }
  23. get isReachable() {
  24. return this.isConfigured && !this.isErrorOccuredOnHealthcheck && !this.isErrorOccuredOnSearching;
  25. }
  26. get isSearchboxEnabled() {
  27. return this.configManager.getConfig('crowi', 'app:searchboxSslUrl') != null;
  28. }
  29. get isElasticsearchEnabled() {
  30. return this.configManager.getConfig('crowi', 'app:elasticsearchUri') != null;
  31. }
  32. generateDelegator() {
  33. logger.info('Initializing search delegator');
  34. if (this.isSearchboxEnabled) {
  35. logger.info('Searchbox is enabled');
  36. const SearchboxDelegator = require('./search-delegator/searchbox.js');
  37. return new SearchboxDelegator(this.configManager, this.crowi.socketIoService);
  38. }
  39. if (this.isElasticsearchEnabled) {
  40. logger.info('Elasticsearch (not Searchbox) is enabled');
  41. const ElasticsearchDelegator = require('./search-delegator/elasticsearch.js');
  42. return new ElasticsearchDelegator(this.configManager, this.crowi.socketIoService);
  43. }
  44. }
  45. registerUpdateEvent() {
  46. const pageEvent = this.crowi.event('page');
  47. pageEvent.on('create', this.delegator.syncPageUpdated.bind(this.delegator));
  48. pageEvent.on('update', this.delegator.syncPageUpdated.bind(this.delegator));
  49. pageEvent.on('delete', this.delegator.syncPageDeleted.bind(this.delegator));
  50. const bookmarkEvent = this.crowi.event('bookmark');
  51. bookmarkEvent.on('create', this.delegator.syncBookmarkChanged.bind(this.delegator));
  52. bookmarkEvent.on('delete', this.delegator.syncBookmarkChanged.bind(this.delegator));
  53. const tagEvent = this.crowi.event('tag');
  54. tagEvent.on('update', this.delegator.syncTagChanged.bind(this.delegator));
  55. }
  56. resetErrorStatus() {
  57. this.isErrorOccuredOnHealthcheck = false;
  58. this.isErrorOccuredOnSearching = false;
  59. }
  60. async reconnectClient() {
  61. logger.info('Try to reconnect...');
  62. this.delegator.initClient();
  63. try {
  64. await this.getInfoForHealth();
  65. logger.info('Reconnecting succeeded.');
  66. this.resetErrorStatus();
  67. }
  68. catch (err) {
  69. throw err;
  70. }
  71. }
  72. async getInfo() {
  73. try {
  74. return await this.delegator.getInfo();
  75. }
  76. catch (err) {
  77. logger.error(err);
  78. throw err;
  79. }
  80. }
  81. async getInfoForHealth() {
  82. try {
  83. const result = await this.delegator.getInfoForHealth();
  84. this.isErrorOccuredOnHealthcheck = false;
  85. return result;
  86. }
  87. catch (err) {
  88. logger.error(err);
  89. // switch error flag, `isErrorOccuredOnHealthcheck` to be `false`
  90. this.isErrorOccuredOnHealthcheck = true;
  91. throw err;
  92. }
  93. }
  94. async getInfoForAdmin() {
  95. return this.delegator.getInfoForAdmin();
  96. }
  97. async normalizeIndices() {
  98. return this.delegator.normalizeIndices();
  99. }
  100. async rebuildIndex() {
  101. return this.delegator.rebuildIndex();
  102. }
  103. async searchKeyword(keyword, user, userGroups, searchOpts) {
  104. try {
  105. return await this.delegator.searchKeyword(keyword, user, userGroups, searchOpts);
  106. }
  107. catch (err) {
  108. logger.error(err);
  109. // switch error flag, `isReachable` to be `false`
  110. this.isErrorOccuredOnSearching = true;
  111. throw err;
  112. }
  113. }
  114. }
  115. module.exports = SearchService;