/// <summary> /// Submit a single script found on a URL/path or a chain of scripts found on a set of URLs/paths /// on the current project. /// /// To submit a chain of repository-managed scripts on this call provide a comma-separated /// list of values on the externalSource parameter. /// /// POWER_USER privileges are required for this call. /// /// </summary> /// <param name="name">Name of the job to schedule</param> /// <param name="descr">Description of the job</param> /// <param name="externalSource">RScript represented as a URL or DeployR file path</param> /// <param name="options">options associated with job</param> /// <returns>RJob object</returns> /// <remarks></remarks> public RJob submitJobExternal(String name, String descr, String externalSource, JobExecutionOptions options) { String uri = Constants.RJOBSUBMIT; if (!(options == null)) { if (!(options.schedulingOptions == null)) { uri = Constants.RJOBSCHEDULE; } } RJob returnValue = RUserJobImpl.callJob(name, descr, "", null, null, null, null, externalSource, options, m_client, uri); return(returnValue); }
/// <summary> /// Submit a single repository-managed script or a chain of repository-managed scripts /// to execute as a job. /// /// To submit a chain of repository-managed scripts on this call provide a comma-separated /// list of values on the scriptName, scriptAuthor and optionally scriptVersion parameters. /// Chained execution executes each of the scripts identified on the call in a sequential /// fashion on the R session, with execution occuring in the order specified on the parameter list. /// /// </summary> /// <param name="name">Name of the job to schedule</param> /// <param name="descr">Description of the job</param> /// <param name="scriptName">name of valid R Script</param> /// <param name="scriptDirectory">directory containing R Script.</param> /// <param name="scriptAuthor">author of the R Script</param> /// <param name="scriptVersion">version of the R Script to execute</param> /// <param name="options">options associated with job</param> /// <returns>RJob object</returns> /// <remarks></remarks> public RJob submitJobScript(String name, String descr, String scriptName, String scriptDirectory, String scriptAuthor, String scriptVersion, JobExecutionOptions options) { String uri = Constants.RJOBSUBMIT; if (!(options == null)) { if (!(options.schedulingOptions == null)) { uri = Constants.RJOBSCHEDULE; } } RJob returnValue = RUserJobImpl.callJob(name, descr, "", scriptName, scriptDirectory, scriptAuthor, scriptVersion, null, options, m_client, uri); return(returnValue); }
public static RJob callJob(String name, String descr, String code, String scriptName, String scriptDirectory, String scriptAuthor, String scriptVersion, String ExternalSource, JobExecutionOptions options, RClient client, String uri) { StringBuilder data = new StringBuilder(); //create the input String data.Append(Constants.FORMAT_JSON); data.Append("&name=" + HttpUtility.UrlEncode(name)); data.Append("&descr=" + HttpUtility.UrlEncode(descr)); data.Append("&code=" + HttpUtility.UrlEncode(code)); if (ExternalSource == null) { data.Append("&rscriptname=" + HttpUtility.UrlEncode(scriptName)); data.Append("&rscriptdirectory=" + HttpUtility.UrlEncode(scriptDirectory)); data.Append("&rscriptauthor=" + HttpUtility.UrlEncode(scriptAuthor)); data.Append("&rscriptversion=" + HttpUtility.UrlEncode(scriptVersion)); } else { data.Append("&externalsource=" + HttpUtility.UrlEncode(ExternalSource)); } if (!(options == null)) { data.Append("&csvinputs=" + HttpUtility.UrlEncode(options.csvrinputs)); if (!(options.rinputs == null)) { if (options.rinputs.Count > 0) { data.Append("&inputs="); String sJSON = JSONSerialize.createJSONfromRData(options.rinputs); data.Append(HttpUtility.UrlEncode(sJSON)); if (HTTPUtilities.DEBUGMODE == true) { Console.Write(sJSON); } } } if (!(options.preloadDirectory == null)) { data.Append("&preloadfilename=" + HttpUtility.UrlEncode(options.preloadDirectory.filename)); data.Append("&preloadfiledirectory=" + HttpUtility.UrlEncode(options.preloadDirectory.directory)); data.Append("&preloadfileauthor=" + HttpUtility.UrlEncode(options.preloadDirectory.author)); data.Append("&preloadfileversion=" + HttpUtility.UrlEncode(options.preloadDirectory.version)); } if (!(options.preloadWorkspace == null)) { data.Append("&preloadobjectname=" + HttpUtility.UrlEncode(options.preloadWorkspace.filename)); data.Append("&preloadobjectdirectory=" + HttpUtility.UrlEncode(options.preloadWorkspace.directory)); data.Append("&preloadobjectauthor=" + HttpUtility.UrlEncode(options.preloadWorkspace.author)); data.Append("&preloadobjectversion=" + HttpUtility.UrlEncode(options.preloadWorkspace.version)); } if (!(options.adoptionOptions == null)) { data.Append("&adoptworkspace=" + HttpUtility.UrlEncode(options.adoptionOptions.adoptWorkspace)); data.Append("&adoptdirectory=" + HttpUtility.UrlEncode(options.adoptionOptions.adoptDirectory)); data.Append("&adoptpackages=" + HttpUtility.UrlEncode(options.adoptionOptions.adoptPackages)); } if (!(options.storageOptions == null)) { data.Append("&storefile=" + HttpUtility.UrlEncode(options.storageOptions.files)); data.Append("&storedirectory=" + HttpUtility.UrlEncode(options.storageOptions.directory)); data.Append("&storeobject=" + HttpUtility.UrlEncode(options.storageOptions.objects)); data.Append("&storeworkspace=" + HttpUtility.UrlEncode(options.storageOptions.workspace)); data.Append("&storenewversion=" + options.storageOptions.newVersion.ToString()); data.Append("&storepublic=" + options.storageOptions.published.ToString()); } if (!(options.routputs == null)) { if (options.routputs.Count > 0) { data.Append("&robjects="); foreach (var s in options.routputs) { data.Append(HttpUtility.UrlEncode(s) + ","); } data.Remove(data.Length - 1, 1); } } data.Append("&echooff=" + options.echooff.ToString()); data.Append("&consoleoff=" + options.consoleoff.ToString()); data.Append("&tag=" + HttpUtility.UrlEncode(options.tag)); data.Append("&graphics=" + HttpUtility.UrlEncode(options.graphicsDevice)); data.Append("&graphicswidth=" + options.graphicsWidth.ToString()); data.Append("&graphicsheight=" + options.graphicsHeight.ToString()); data.Append("&nan=" + HttpUtility.UrlEncode(options.nan)); data.Append("&infinity=" + HttpUtility.UrlEncode(options.infinity)); data.Append("&encodeDataFramePrimitiveAsVector=" + options.encodeDataFramePrimitiveAsVector.ToString()); data.Append("&enableConsoleEvents=" + options.enableConsoleEvents.ToString()); data.Append("&preloadbydirectory=" + HttpUtility.UrlEncode(options.preloadByDirectory)); if (!(options.schedulingOptions == null)) { data.Append("&schedstart=" + options.schedulingOptions.startTime.ToString()); data.Append("&schedrepeat=" + options.schedulingOptions.repeatCount.ToString()); data.Append("&schedinterval=" + options.schedulingOptions.repeatInterval.ToString()); } data.Append("&storenoproject=" + options.noProject.ToString()); data.Append("&priority=" + HttpUtility.UrlEncode(options.priority)); data.Append("&cluster=" + HttpUtility.UrlEncode(options.gridCluster)); } //call the server JSONResponse jresponse = HTTPUtilities.callRESTPost(uri, data.ToString(), ref client); RJob returnValue = new RJob(jresponse, client); return returnValue; }
/// <summary> /// Submit a job based on block of R code /// </summary> /// <param name="name">Name of the job to schedule</param> /// <param name="descr">Description of the job</param> /// <param name="code">R code associated with the job</param> /// <returns>RJob object</returns> /// <remarks></remarks> public RJob submitJobCode(String name, String descr, String code) { RJob returnValue = RUserJobImpl.callJob(name, descr, code, "", "", "", "", null, null, m_client, Constants.RJOBSUBMIT); return(returnValue); }
/// <summary> /// Submit a single repository-managed script or a chain of repository-managed scripts /// to execute as a job. /// /// To submit a chain of repository-managed scripts on this call provide a comma-separated /// list of values on the scriptName, scriptAuthor and optionally scriptVersion parameters. /// Chained execution executes each of the scripts identified on the call in a sequential /// fashion on the R session, with execution occuring in the order specified on the parameter list. /// /// </summary> /// <param name="name">Name of the job to schedule</param> /// <param name="descr">Description of the job</param> /// <param name="scriptName">name of valid R Script</param> /// <param name="scriptDirectory">directory containing R Script.</param> /// <param name="scriptAuthor">author of the R Script</param> /// <param name="scriptVersion">version of the R Script to execute</param> /// <returns>RJob object</returns> /// <remarks></remarks> public RJob submitJobScript(String name, String descr, String scriptName, String scriptDirectory, String scriptAuthor, String scriptVersion) { RJob returnValue = RUserJobImpl.callJob(name, descr, "", scriptName, scriptDirectory, scriptAuthor, scriptVersion, null, null, m_client, Constants.RJOBSUBMIT); return(returnValue); }
static public RJob callJob(String name, String descr, String code, String scriptName, String scriptDirectory, String scriptAuthor, String scriptVersion, String ExternalSource, JobExecutionOptions options, RClient client, String uri) { StringBuilder data = new StringBuilder(); //create the input String data.Append(Constants.FORMAT_JSON); data.Append("&name=" + HttpUtility.UrlEncode(name)); data.Append("&descr=" + HttpUtility.UrlEncode(descr)); data.Append("&code=" + HttpUtility.UrlEncode(code)); if (ExternalSource == null) { data.Append("&rscriptname=" + HttpUtility.UrlEncode(scriptName)); data.Append("&rscriptdirectory=" + HttpUtility.UrlEncode(scriptDirectory)); data.Append("&rscriptauthor=" + HttpUtility.UrlEncode(scriptAuthor)); data.Append("&rscriptversion=" + HttpUtility.UrlEncode(scriptVersion)); } else { data.Append("&externalsource=" + HttpUtility.UrlEncode(ExternalSource)); } if (!(options == null)) { data.Append("&csvinputs=" + HttpUtility.UrlEncode(options.csvrinputs)); if (!(options.rinputs == null)) { if (options.rinputs.Count > 0) { data.Append("&inputs="); String sJSON = JSONSerialize.createJSONfromRData(options.rinputs); data.Append(HttpUtility.UrlEncode(sJSON)); if (HTTPUtilities.DEBUGMODE == true) { Console.Write(sJSON); } } } if (!(options.preloadDirectory == null)) { data.Append("&preloadfilename=" + HttpUtility.UrlEncode(options.preloadDirectory.filename)); data.Append("&preloadfiledirectory=" + HttpUtility.UrlEncode(options.preloadDirectory.directory)); data.Append("&preloadfileauthor=" + HttpUtility.UrlEncode(options.preloadDirectory.author)); data.Append("&preloadfileversion=" + HttpUtility.UrlEncode(options.preloadDirectory.version)); } if (!(options.preloadWorkspace == null)) { data.Append("&preloadobjectname=" + HttpUtility.UrlEncode(options.preloadWorkspace.filename)); data.Append("&preloadobjectdirectory=" + HttpUtility.UrlEncode(options.preloadWorkspace.directory)); data.Append("&preloadobjectauthor=" + HttpUtility.UrlEncode(options.preloadWorkspace.author)); data.Append("&preloadobjectversion=" + HttpUtility.UrlEncode(options.preloadWorkspace.version)); } if (!(options.adoptionOptions == null)) { data.Append("&adoptworkspace=" + HttpUtility.UrlEncode(options.adoptionOptions.adoptWorkspace)); data.Append("&adoptdirectory=" + HttpUtility.UrlEncode(options.adoptionOptions.adoptDirectory)); data.Append("&adoptpackages=" + HttpUtility.UrlEncode(options.adoptionOptions.adoptPackages)); } if (!(options.storageOptions == null)) { data.Append("&storefile=" + HttpUtility.UrlEncode(options.storageOptions.files)); data.Append("&storedirectory=" + HttpUtility.UrlEncode(options.storageOptions.directory)); data.Append("&storeobject=" + HttpUtility.UrlEncode(options.storageOptions.objects)); data.Append("&storeworkspace=" + HttpUtility.UrlEncode(options.storageOptions.workspace)); data.Append("&storenewversion=" + options.storageOptions.newVersion.ToString()); data.Append("&storepublic=" + options.storageOptions.published.ToString()); } if (!(options.routputs == null)) { if (options.routputs.Count > 0) { data.Append("&robjects="); foreach (var s in options.routputs) { data.Append(HttpUtility.UrlEncode(s) + ","); } data.Remove(data.Length - 1, 1); } } data.Append("&echooff=" + options.echooff.ToString()); data.Append("&consoleoff=" + options.consoleoff.ToString()); data.Append("&tag=" + HttpUtility.UrlEncode(options.tag)); data.Append("&graphics=" + HttpUtility.UrlEncode(options.graphicsDevice)); data.Append("&graphicswidth=" + options.graphicsWidth.ToString()); data.Append("&graphicsheight=" + options.graphicsHeight.ToString()); data.Append("&nan=" + HttpUtility.UrlEncode(options.nan)); data.Append("&infinity=" + HttpUtility.UrlEncode(options.infinity)); data.Append("&encodeDataFramePrimitiveAsVector=" + options.encodeDataFramePrimitiveAsVector.ToString()); data.Append("&enableConsoleEvents=" + options.enableConsoleEvents.ToString()); data.Append("&preloadbydirectory=" + HttpUtility.UrlEncode(options.preloadByDirectory)); if (!(options.schedulingOptions == null)) { data.Append("&schedstart=" + options.schedulingOptions.startTime.ToString()); data.Append("&schedrepeat=" + options.schedulingOptions.repeatCount.ToString()); data.Append("&schedinterval=" + options.schedulingOptions.repeatInterval.ToString()); } data.Append("&storenoproject=" + options.noProject.ToString()); data.Append("&priority=" + HttpUtility.UrlEncode(options.priority)); data.Append("&cluster=" + HttpUtility.UrlEncode(options.gridCluster)); } //call the server JSONResponse jresponse = HTTPUtilities.callRESTPost(uri, data.ToString(), ref client); RJob returnValue = new RJob(jresponse, client); return(returnValue); }