Skip to content

Commit

Permalink
implementation updateSchema method
Browse files Browse the repository at this point in the history
Issue #554
  • Loading branch information
rsoika committed Aug 29, 2019
1 parent 79a6e0e commit 6a28c47
Showing 1 changed file with 88 additions and 55 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -111,102 +111,135 @@ public void init() {
* than the method creates a new empty core
*
* @param setupEvent
* @throws RestAPIException
*/
@SuppressWarnings("unused")
public void setup(@Observes SetupEvent setupEvent) {
public void setup(@Observes SetupEvent setupEvent) throws RestAPIException {

logger.info("...verify solr core '" + core + "'...");

// try to get the schma of the core...
try {
String schema = restClient.get(host + "/api/cores/" + core + "/schema");
logger.info("...solr core '" + core + "' OK ");
String existingSchema = restClient.get(host + "/api/cores/" + core + "/schema");
logger.info("...core = OK ");

// update schema
updateSchema(existingSchema);
} catch (RestAPIException e) {
// no schema found
logger.info("...no solr core '" + core + "' found!");
try {
createCore();
} catch (RestAPIException e1) {
logger.warning("Failed to verify solr core - " + e1.getMessage());
e1.printStackTrace();
}
logger.severe("...no solr core '" + core + "' found!");
throw e;
}

}

/**
* This method returns a JSON structure to create all fields to be added into a
* empty schema.
* Creates a new solr core and updates the schema defintion
* <p>
* In case no core yet exits, the method tries to create a new one. This
* typically is necessary after first deployment.
*
* @param prop
* @return
* @throws IOException
* @throws Exception
*/
public void updateSchema(String schema) throws RestAPIException {

// create the schema....
String schemaUpdate = createUpdateSchema(schema);
// test if the schemaUdpate contains instructions....
if (!"{}".equals(schemaUpdate)) {
String uri = host + "/api/cores/" + core + "/schema";
logger.info("...update schema '" + core + "':");
logger.info("..." + schemaUpdate);
restClient.post(uri, schemaUpdate, "application/json");
} else {
logger.info("...schema = OK ");
}
}

/**
* This method returns a JSON structure to to update an existing Solr schema.
* The method adds all fields into a solr update definition that did not yet
* exist in the current schema.
* <p>
* This is used during creation of a new empty core
* The param schema contains the current schema definition of the core.
*
* @return
*/
public String getSchemaUpdate() {
private String createUpdateSchema(String oldSchema) {

StringBuffer schema = new StringBuffer();
StringBuffer updateSchema = new StringBuffer();
List<String> fieldListStore = schemaService.getFieldListStore();
List<String> fieldListAnalyse = schemaService.getFieldListAnalyse();
List<String> fieldListNoAnalyse = schemaService.getFieldListNoAnalyse();
schema.append("{");

// finally add the default content field
schema.append("\"add-field\":{\"name\":\"content\",\"type\":\"TextField\",\"stored\":false },");
// remove white space from oldSchema to simplify string compare...
oldSchema = oldSchema.replace(" ", "");

updateSchema.append("{");

// finally add the default content field
addFieldIntoUpdateSchema(updateSchema, oldSchema, "content", "text_general", false);
// add each field from the fieldListAnalyse
for (String field : fieldListAnalyse) {
boolean store = fieldListStore.contains(field);
schema.append("\"add-field\":{\"name\":\"" + field + "\",\"type\":\"StrField\",\"stored\":" + store + " },");
}
// add each field from the fieldListAnalyse
for (String field : fieldListAnalyse) {
boolean store = fieldListStore.contains(field);
schema.append("\"add-field\":{\"name\":\"" + field + "\",\"type\":\"TextField\",\"stored\":" + store + " },");
addFieldIntoUpdateSchema(updateSchema, oldSchema, field, "text_general", store);
}

// add each field from the fieldListNoAnalyse
for (String field : fieldListNoAnalyse) {
boolean store = fieldListStore.contains(field);
schema.append("\"add-field\":{\"name\":\"" + field + "\",\"type\":\"StrField\",\"stored\":" + store + " },");
addFieldIntoUpdateSchema(updateSchema, oldSchema, field, "strings", store);
}

// doc.add(new TextField("content", sContent, Store.NO));

// finally add the $uniqueid field
schema.append("\"add-field\":{\"name\":\"$uniqueid\",\"type\":\"StrField\",\"stored\":true }");
addFieldIntoUpdateSchema(updateSchema, oldSchema, "$uniqueid", "string", true);

schema.append("}");

return schema.toString();
// remove last ,
int lastComma = updateSchema.lastIndexOf(",");
if (lastComma > -1) {
updateSchema.deleteCharAt(lastComma);
}
updateSchema.append("}");
return updateSchema.toString();
}

/**
* Creates a new solr core and updates the schema defintion
* This method adds a 'add-field' object to an updateSchema.
* <p>
* In case no core yet exits, the method tries to create a new one. This
* typically is necessary after first deployment.
* In case the same field already exists in the oldSchema then the method will
* not add the field to the update schema.
* <p>
* Example: <code>{name=$workflowsummary, type=text_general, stored=true}</code>
*
* <p>
* NOTE: The test here is very week (simple indexOf) and may cause problems in
* the future. TODO optimize the schema compare method.
*
* @param updateSchema
* - a stringBuffer containing the update schema
* @param oldSchema
* - the current schema definition
* @param name
* - field name
* @param type
* - field type
* @param store
* - boolean store field
* @param addComma
* - true if a ',' should be added to the end of the updateSchema.
*
* @param prop
* @return
* @throws IOException
* @throws Exception
*/
private void createCore() throws RestAPIException {

String uri = host + "/solr/admin/cores?action=CREATE&name=" + core + "&instanceDir=" + core
+ "&configSet=/opt/solr/server/solr/configsets/" + configset;

logger.info("...creating solr core '" + core + "' with configset '" + configset + "'");
restClient.get(uri);

// create the schema....
String schemaUpdate = getSchemaUpdate();

uri = host + "/api/cores/" + core + "/schema";

logger.info("...update schema information");
restClient.post(uri, schemaUpdate, "application/json");

private void addFieldIntoUpdateSchema(StringBuffer updateSchema, String oldSchema, String name, String type,
boolean store) {

String fieldDefinition = "{\"name\":\"" + name + "\",\"type\":\"" + type + "\",\"stored\":" + store + "}";
// test if this field discription already exists
if (!oldSchema.contains(fieldDefinition)) {
// add new field to updateSchema....
updateSchema.append("\"add-field\":" + fieldDefinition + ",");
}
}

}

0 comments on commit 6a28c47

Please sign in to comment.