diff options
| author | srichman333 <sarah_n_richman@brown.edu> | 2023-06-14 17:23:23 -0400 | 
|---|---|---|
| committer | srichman333 <sarah_n_richman@brown.edu> | 2023-06-14 17:23:23 -0400 | 
| commit | f0474c18d092f4db49255a1e92d7f052b7398897 (patch) | |
| tree | 1e26ccaf42dec4d99904e2eddb36dff6f3b55948 /src/server/ApiManagers/SearchManager.ts | |
| parent | 20d217d825891cf29a432a048d1f8e7bc04d062a (diff) | |
| parent | bf1198fbe73847087b1ec8e00a43306816b3508a (diff) | |
Merge branch 'master' into collaboration-sarah
Diffstat (limited to 'src/server/ApiManagers/SearchManager.ts')
| -rw-r--r-- | src/server/ApiManagers/SearchManager.ts | 151 | 
1 files changed, 74 insertions, 77 deletions
| diff --git a/src/server/ApiManagers/SearchManager.ts b/src/server/ApiManagers/SearchManager.ts index a74e13a62..186f0bcd3 100644 --- a/src/server/ApiManagers/SearchManager.ts +++ b/src/server/ApiManagers/SearchManager.ts @@ -1,94 +1,89 @@ -import { exec } from "child_process"; -import { cyan, green, red, yellow } from "colors"; +import { exec } from 'child_process'; +import { cyan, green, red, yellow } from 'colors';  import * as path from 'path'; -import { log_execution } from "../ActionUtilities"; -import { Database } from "../database"; -import { Method } from "../RouteManager"; -import RouteSubscriber from "../RouteSubscriber"; -import { Search } from "../Search"; -import ApiManager, { Registration } from "./ApiManager"; -import { Directory, pathToDirectory } from "./UploadManager"; +import { log_execution } from '../ActionUtilities'; +import { Database } from '../database'; +import { Method } from '../RouteManager'; +import RouteSubscriber from '../RouteSubscriber'; +import { Search } from '../Search'; +import ApiManager, { Registration } from './ApiManager'; +import { Directory, pathToDirectory } from './UploadManager';  const findInFiles = require('find-in-files');  export class SearchManager extends ApiManager { -      protected initialize(register: Registration): void { -          register({              method: Method.GET, -            subscription: new RouteSubscriber("solr").add("action"), +            subscription: new RouteSubscriber('solr').add('action'),              secureHandler: async ({ req, res }) => {                  const { action } = req.params;                  switch (action) { -                    case "start": -                    case "stop": -                        const status = req.params.action === "start"; +                    case 'start': +                    case 'stop': +                        const status = req.params.action === 'start';                          SolrManager.SetRunning(status);                          break; -                    case "update": +                    case 'update':                          await SolrManager.update();                          break;                      default:                          console.log(yellow(`${action} is an unknown solr operation.`));                  } -                res.redirect("/home"); -            } +                res.redirect('/home'); +            },          });          register({              method: Method.GET, -            subscription: "/textsearch", +            subscription: '/textsearch',              secureHandler: async ({ req, res }) => {                  const q = req.query.q;                  if (q === undefined) {                      res.send([]);                      return;                  } -                const resObj: { ids: string[], numFound: number, lines: string[] } = { ids: [], numFound: 0, lines: [] }; +                const resObj: { ids: string[]; numFound: number; lines: string[] } = { ids: [], numFound: 0, lines: [] };                  let results: any;                  const dir = pathToDirectory(Directory.text);                  try {                      const regex = new RegExp(q.toString()); -                    results = await findInFiles.find({ 'term': q, 'flags': 'ig' }, dir, ".txt$"); +                    results = await findInFiles.find({ term: q, flags: 'ig' }, dir, '.txt$');                      for (const result in results) { -                        resObj.ids.push(path.basename(result, ".txt").replace(/upload_/, "")); +                        resObj.ids.push(path.basename(result, '.txt').replace(/upload_/, ''));                          resObj.lines.push(results[result].line);                          resObj.numFound++;                      }                      res.send(resObj);                  } catch (e) { -                    console.log(red("textsearch:bad RegExp" + q.toString())); +                    console.log(red('textsearch:bad RegExp' + q.toString()));                      res.send([]);                      return;                  } -            } +            },          });          register({              method: Method.GET, -            subscription: "/dashsearch", +            subscription: '/dashsearch',              secureHandler: async ({ req, res }) => {                  const solrQuery: any = {}; -                ["q", "fq", "start", "rows", "sort", "hl.maxAnalyzedChars", "hl", "hl.fl"].forEach(key => solrQuery[key] = req.query[key]); +                ['q', 'fq', 'start', 'rows', 'sort', 'hl.maxAnalyzedChars', 'hl', 'hl.fl'].forEach(key => (solrQuery[key] = req.query[key]));                  if (solrQuery.q === undefined) {                      res.send([]);                      return;                  }                  const results = await Search.search(solrQuery);                  res.send(results); -            } +            },          }); -      } -  }  export namespace SolrManager { -      export function SetRunning(status: boolean) { -        const args = status ? "start" : "stop -p 8983"; +        const args = status ? 'start' : 'stop -p 8983';          console.log(`solr management: trying to ${args}`); -        exec(`solr ${args}`, { cwd: "./solr-8.3.1/bin" }, (error, stdout, stderr) => { +        exec(`solr ${args}`, { cwd: './solr-8.3.1/bin' }, (error, stdout, stderr) => {              if (error) {                  console.log(red(`solr management error: unable to ${args} server`));                  console.log(red(error.message)); @@ -97,39 +92,39 @@ export namespace SolrManager {              console.log(yellow(stderr));          });          if (status) { -            console.log(cyan("Start script is executing: please allow 15 seconds for solr to start on port 8983.")); +            console.log(cyan('Start script is executing: please allow 15 seconds for solr to start on port 8983.'));          }      }      export async function update() { -        console.log(green("Beginning update...")); +        console.log(green('Beginning update...'));          await log_execution<void>({ -            startMessage: "Clearing existing Solr information...", -            endMessage: "Solr information successfully cleared", +            startMessage: 'Clearing existing Solr information...', +            endMessage: 'Solr information successfully cleared',              action: Search.clear, -            color: cyan +            color: cyan,          });          const cursor = await log_execution({ -            startMessage: "Connecting to and querying for all documents from database...", +            startMessage: 'Connecting to and querying for all documents from database...',              endMessage: ({ result, error }) => {                  const success = error === null && result !== undefined;                  if (!success) { -                    console.log(red("Unable to connect to the database.")); +                    console.log(red('Unable to connect to the database.'));                      process.exit(0);                  } -                return "Connection successful and query complete"; +                return 'Connection successful and query complete';              },              action: () => Database.Instance.query({}), -            color: yellow +            color: yellow,          });          const updates: any[] = [];          let numDocs = 0;          function updateDoc(doc: any) {              numDocs++; -            if ((numDocs % 50) === 0) { +            if (numDocs % 50 === 0) {                  console.log(`Batch of 50 complete, total of ${numDocs}`);              } -            if (doc.__type !== "Doc") { +            if (doc.__type !== 'Doc') {                  return;              }              const fields = doc.fields; @@ -143,8 +138,8 @@ export namespace SolrManager {                  const term = ToSearchTerm(value);                  if (term !== undefined) {                      const { suffix, value } = term; -                    if (key.endsWith('lastModified')) { -                        update["lastModified" + suffix] = value; +                    if (key.endsWith('modificationDate')) { +                        update['modificationDate' + suffix] = value;                      }                      update[key + suffix] = value;                      dynfield = true; @@ -157,51 +152,54 @@ export namespace SolrManager {          await cursor?.forEach(updateDoc);          const result = await log_execution({              startMessage: `Dispatching updates for ${updates.length} documents`, -            endMessage: "Dispatched updates complete", +            endMessage: 'Dispatched updates complete',              action: () => Search.updateDocuments(updates), -            color: cyan +            color: cyan,          });          try {              if (result) {                  const { status } = JSON.parse(result).responseHeader; -                console.log(status ? red(`Failed with status code (${status})`) : green("Success!")); +                console.log(status ? red(`Failed with status code (${status})`) : green('Success!'));              } else { -                console.log(red("Solr is likely not running!")); +                console.log(red('Solr is likely not running!'));              }          } catch (e) { -            console.log(red("Error:")); +            console.log(red('Error:'));              console.log(e); -            console.log("\n"); +            console.log('\n');          }          await cursor?.close();      } -    const suffixMap: { [type: string]: (string | [string, string | ((json: any) => any)]) } = { -        "number": "_n", -        "string": "_t", -        "boolean": "_b", -        "image": ["_t", "url"], -        "video": ["_t", "url"], -        "pdf": ["_t", "url"], -        "audio": ["_t", "url"], -        "web": ["_t", "url"], -        "map": ["_t", "url"], -        "date": ["_d", value => new Date(value.date).toISOString()], -        "proxy": ["_i", "fieldId"], -        "prefetch_proxy": ["_i", "fieldId"], -        "list": ["_l", list => { -            const results = []; -            for (const value of list.fields) { -                const term = ToSearchTerm(value); -                if (term) { -                    results.push(term.value); +    const suffixMap: { [type: string]: string | [string, string | ((json: any) => any)] } = { +        number: '_n', +        string: '_t', +        boolean: '_b', +        image: ['_t', 'url'], +        video: ['_t', 'url'], +        pdf: ['_t', 'url'], +        audio: ['_t', 'url'], +        web: ['_t', 'url'], +        map: ['_t', 'url'], +        date: ['_d', value => new Date(value.date).toISOString()], +        proxy: ['_i', 'fieldId'], +        prefetch_proxy: ['_i', 'fieldId'], +        list: [ +            '_l', +            list => { +                const results = []; +                for (const value of list.fields) { +                    const term = ToSearchTerm(value); +                    if (term) { +                        results.push(term.value); +                    }                  } -            } -            return results.length ? results : null; -        }] +                return results.length ? results : null; +            }, +        ],      }; -    function ToSearchTerm(val: any): { suffix: string, value: any } | undefined { +    function ToSearchTerm(val: any): { suffix: string; value: any } | undefined {          if (val === null || val === undefined) {              return;          } @@ -213,7 +211,7 @@ export namespace SolrManager {          if (Array.isArray(suffix)) {              const accessor = suffix[1]; -            if (typeof accessor === "function") { +            if (typeof accessor === 'function') {                  val = accessor(val);              } else {                  val = val[accessor]; @@ -223,5 +221,4 @@ export namespace SolrManager {          return { suffix, value: val };      } - -}
\ No newline at end of file +} | 
