All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.cyc.kb.client.config.KbConfiguration Maven / Gradle / Ivy

package com.cyc.kb.client.config;

/*
 * #%L
 * File: KbConfiguration.java
 * Project: KB Client
 * %%
 * Copyright (C) 2013 - 2017 Cycorp, Inc
 * %%
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 * 
 *      http://www.apache.org/licenses/LICENSE-2.0
 * 
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 * #L%
 */

import com.cyc.kb.DefaultContext;
import com.cyc.base.cycobject.Fort;
import com.cyc.baseclient.CycClientOptions;
import com.cyc.kb.KbIndividual;
import com.cyc.kb.client.KbIndividualImpl;
import com.cyc.kb.exception.KbRuntimeException;
import com.cyc.session.CycSessionManager;
import com.cyc.session.exception.SessionException;


/**
 * A class to hold the configuration parameters such as, transcript flag, current cyclist 
 * and current project. 
 * 
 * A cleaner configuration project is being worked on. This class will be deprecated 
 * by that in the next few months.
 * @author vijay
 * 
 * 
 */
public class KbConfiguration {

  public static CycClientOptions getOptions() {
    try {
      return (CycClientOptions) CycSessionManager.getCurrentSession().getOptions();
    } catch (SessionException ex) {
      throw new KbRuntimeException(ex);
    }
  }
  
  /* *
   * Gates whether KB operations are transcripted.
   * /
  private static ThreadLocal shouldTranscriptOperations =
          new ThreadLocal() {
    @Override
    protected Boolean initialValue() {
      return true;
    }
  };
  
  static private CycAccess getStaticAccess() {
    try {
      return CycAccessManager.getCurrentAccess();
    } catch (SessionApiException ex) {
      throw new KBApiRuntimeException(ex.getMessage(), ex);
    }
  }
  
  /* *
   * Sets an initial default context for assertions and queries.
   * 
   * Initially, the default contexts are:
   *  forAssertion: null
   *  forQuery: null
   * These are set to null values to encourage developers to set the defaults
   * explicitly.
   * 
   * If the program does not have an application specific default, the following
   * could be used.
   * 	forAssertion: #$UniversalVocabularyMt
   * 	forQuery: #$InferencePSC
   * /
  private static ThreadLocal defaultContext =
		  new ThreadLocal() {
	  @Override
	  protected DefaultContext initialValue() {
		  // return new KBAPIDefaultContext(Constants.uvMt(), Constants.inferencePSCMt());
		  return new KBAPIDefaultContext(null, null);
	  }
  };
  
  /* *
   * Sets the default context ThreadLocal
   * @param defaultCtxs
   * /
  public static void setDefaultContext(DefaultContext defaultCtxs) {
	  defaultContext.set(defaultCtxs);
  }
  */
  
  /**
   * Returns the current default contexts
   * @return the contents of the DefaultContest ThreadLocal
   */
  public static DefaultContext getDefaultContext() {
    return getOptions().getDefaultContext();
  }

  /* *
   * Declare that KB operations performed in this thread should or shouldn't be
   * transcripted by the Cyc server.
   * 
   * @param b flag to control the transcription of the operations
   * /
  public static void setShouldTranscriptOperations(final boolean b) {
    shouldTranscriptOperations.set(b);
  }
  */
  
  /**
   * Will actions in the current thread that modify the KB be transcripted by
   * the Cyc server?
   *
   * @return will KB operations from the current thread be transcripted?
   */
  public static boolean getShouldTranscriptOperations() {
    //return shouldTranscriptOperations.get();
    return getOptions().getShouldTranscriptOperations();
  }

  /**
   * The Cyclist or the program running on behalf of the cyclist generating the
   * operations in this thread. Return null if not set of if there is any exception.
   * 
   * @return the cyclist or the program running on behalf of a cyclist, that is
   * generating the operations in this thread
   */
  @SuppressWarnings("deprecation")
  public static KbIndividual getCurrentCyclist() {
    // Since the KB API does not provide any method to set Cyclist per CycAccess,
    // boldly assuming that what we return is always the thread version of Cyclist.
    try {
      //Fort cyclist = getStaticAccess().getOptions().getCyclist();
      Fort cyclist = getOptions().getCyclist();
      if (cyclist == null) {
        return null;
      }
      return KbIndividualImpl.get(cyclist);
    } catch (Exception e) {
      return null;
    }
  }
  
  /* *
   * Declare that KB operations performed in this thread were done by the user 
   * cyclist.
   * The user could be an individual #$Cyclist or an instance of #$ComputerUser, 
   * such as, (UserOfProgramFn CycBrowser CAEUser). Applications written on top 
   * of KB API should login an user and create an instance of UserOfProgramFn, based
   * on the application and the user.
   * This will set #$myCreator for constants and :ASSERT-INFO for assertions
   * 
   * @param cyclist the person or program creating constants and assertions
   * 
   * @return the back cyclist set
   * /  
  public static KBIndividual setCurrentCyclist(KBIndividualImpl cyclist) {
    getStaticAccess().getOptions().setCyclist((Fort)cyclist.getCore());
    return cyclist;
  }
    
  /* *
   * Declare that KB operations performed in this thread were done by the user 
   * cyclistStr.
   * The user could be an individual #$Cyclist or an instance of #$ComputerUser, 
   * such as, (UserOfProgramFn CycBrowser CAEUser). Applications written on top 
   * of KB API should login an user and create an instance of UserOfProgramFn, based
   * on the application and the user. 
   * This will set #$myCreator for constants and :ASSERT-INFO for assertions
   * @param cyclistStr  string representation of the cyclist creating constants
   * and assertions
   * @return the Cyclist created based on cyclistStr
   * /
  @SuppressWarnings("deprecation")
  public static KBIndividual setCurrentCyclist(String cyclistStr){
    try {
      String cyclist = getStaticAccess().cyclifyString(cyclistStr);
      getStaticAccess().getOptions().setCyclistName(cyclist);
      return KBIndividualImpl.get(cyclist);
    } catch (SessionApiException ex) {
      throw new KBApiRuntimeException(ex.getMessage(), ex);
    } catch (CycConnectionException ex) {
      throw new KBApiRuntimeException(ex.getMessage(), ex);
    } catch (CycApiException ex) {
      throw new KBApiRuntimeException(ex.getMessage(), ex);
    } catch (KBTypeException ex) {
      throw new KBApiRuntimeException(ex.getMessage(), ex);
    } catch (CreateException ex) {
      throw new KBApiRuntimeException(ex.getMessage(), ex);
    }
  }

  /* *
   * Declare that the KB operations performed in this thread are related to the specified
   * project. The project should be an instance of #$Cyc-BasedProject. Applications written
   * on top of KB API should set the purpose on their own or by asking the user at login time.
   * 
   * Sets the #$myCreationPurpose for constants and :ASSERT-INFO for assertions.
   * @param project an instance of #$Cyc-BasedProject
   * @throws Exception 
   * /
  public static void setProject (KBIndividual project) throws Exception {
    getStaticAccess().getOptions().setKePurpose((Fort)project.getCore());
  }
  
  /* *
   * Get the project that the KB operations performed in this thread are related to. 
   * The project will be an instance of #$Cyc-BasedProject. Return null if unknown
   * or if there is any exception.
   * 
   * @return the project related to the current run of the program
   * /  
  @SuppressWarnings("deprecation")
  public KBIndividual getProject() {
    try {
      Fort purpose = getStaticAccess().getOptions().getKePurpose();
      if (purpose == null){
        return null;
      }
      return KBIndividualImpl.get(purpose);
    } catch (Exception e) {
      return null;
    }
  }
  */
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy