Cancel Inspection
GetInspectionsToCancel will return the inspection type and sequence number that you will need to pass to this method in order to cancel it. It also returns the current status, indicating if it is already cancelled or approved.
This method does not return the normal error code. It returns the inspection description of the inspection that was cancelled.
Name | Type | Length | Description |
---|---|---|---|
applicationYear | numeric | 2 | [Required] Application Year. 2 digit |
applicationNumber | numeric | 8 | [Required] Application Number |
startNumber | numeric | 3 | [Required] Start Number. For a permit, Ex: 000 000 BLDG 01, this is the first set of three numbers. |
startSequence | numeric | 3 | [Required] Start Sequence. For a permit, Ex: 000 000 BLDG 01, this is the second set of three numbers. |
permitType | System.String | 4 | [Required] Permit Type. For a permit, Ex: 000 000 BLDG 01, this is the third set of four characters, which has to be one of the permit type codes. |
permitSequence | numeric | 2 | [Required] Permit Sequence. For a permit, Ex: 000 000 BLDG 01, this is the fourth set of two numbers. |
inspectionType | System.String | 4 | [Required] Inspection Type. 4 char code. Ex. BL02 |
inspectionSequence | numeric | 4 | [Required] sequence number for inspection |
POST http://localhost/FusionServices/v3/Naviline/Inspection/Cancel
Name | Description |
---|---|
IDES | Inspection description of the inspection that was cancelled. |
using System.Net;
using Newtonsoft.Json.Linq;
public void MethodName(parms)
{
string uri = "http://localhost/FusionServices/v3/Naviline/Inspection/Cancel";
System.Collections.Specialized.NameValueCollection postParms =
new System.Collections.Specialized.NameValueCollection();
// Set paramater values
postParms.Add("applicationYear",System.Web.HttpUtility.UrlEncode("09"));
postParms.Add("applicationNumber",System.Web.HttpUtility.UrlEncode("502"));
postParms.Add("startNumber",System.Web.HttpUtility.UrlEncode("000"));
postParms.Add("startSequence",System.Web.HttpUtility.UrlEncode("000"));
postParms.Add("permitType",System.Web.HttpUtility.UrlEncode("BLDG"));
postParms.Add("permitSequence",System.Web.HttpUtility.UrlEncode("00"));
postParms.Add("inspectionType",System.Web.HttpUtility.UrlEncode("BL11"));
postParms.Add("inspectionSequence",System.Web.HttpUtility.UrlEncode("0016"));
WebClient req = new WebClient();
wc.Headers.Add("Content-Type", "application/x-www-form-urlencoded");
wc.Headers.Set("X-APPID", "YOURID");
wc.Headers.Set("X-APPKEY", "YOURKEY");
byte[] responseBytes = wc.UploadValues(new Uri(uri), "POST", postParms);
string stringResult = Encoding.UTF8.GetString(responseBytes);
JObject response = JObject.Parse(stringResult);
string inspectionDesc = response["OutputParms"]["IDES"].ToString();
if (inspectionDesc.Length > 0)
{
// TODO - YOUR CODE HERE
}
}
using System;
using System.Linq;
using System.Web;
using System.ComponentModel.DataAnnotations;
using System.Collections.Specialized;
using FusionServiceHelper.Models;
// NOTE: Use the namespace generated when you add the class, so that it is correct.
namespace FusionRazor.Models
{
public class PostCancelInspection
{
// Add property for each input param in order to map a field to it
[Required(ErrorMessage = "Required")]
[RegularExpression("[0-9]{0,2}", ErrorMessage = "Numeric values only. Must be 2 digits or less. ")]
public string applicationYear{get; set;}
[Required(ErrorMessage = "Required")]
[RegularExpression("[0-9]{0,8}", ErrorMessage = "Numeric values only. Must be 8 digits or less. ")]
public string applicationNumber{get; set;}
[Required(ErrorMessage = "Required")]
[RegularExpression("[0-9]{0,3}", ErrorMessage = "Numeric values only. Must be 3 digits or less. ")]
public string startNumber{get; set;}
[Required(ErrorMessage = "Required")]
[RegularExpression("[0-9]{0,3}", ErrorMessage = "Numeric values only. Must be 3 digits or less. ")]
public string startSequence{get; set;}
[Required(ErrorMessage = "Required")]
[RegularExpression("^(?=.{0,4}$).*", ErrorMessage = "Must be 4 characters or less. ")]
public string permitType{get; set;}
[Required(ErrorMessage = "Required")]
[RegularExpression("[0-9]{0,2}", ErrorMessage = "Numeric values only. Must be 2 digits or less. ")]
public string permitSequence{get; set;}
[Required(ErrorMessage = "Required")]
[RegularExpression("^(?=.{0,4}$).*", ErrorMessage = "Must be 4 characters or less. ")]
public string inspectionType{get; set;}
[Required(ErrorMessage = "Required")]
[RegularExpression("[0-9]{0,4}", ErrorMessage = "Numeric values only. Must be 4 digits or less. ")]
public string inspectionSequence{get; set;}
public PostCancelInspection()
{
//Set any defaults here
}
}
}
@* NOTE: Use Add->View to add the View. *@
@* NOTE: Check the 'Create strongly-typed view checkbox, and select the PostCancelInspection class. *@
@* NOTE: Select Edit as the Scaffold template. *@
@* NOTE: Use the @model line that is generated at the top. Replace the rest with the lines below.
@model FusionRazor.Models.PostCancelInspection
@{
ViewBag.Title = "PostCancelInspection";
}
<h2>PostCancelInspection</h2>
@using (Html.BeginForm()) {
@Html.AntiForgeryToken()
@Html.ValidationSummary(true)
<fieldset>
<legend>PostCancelInspection</legend>
<div class="editor-label">
@Html.LabelFor(model => model.applicationYear)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.applicationYear)
@Html.ValidationMessageFor(model => model.applicationYear)
</div>
<div class="editor-label">
@Html.LabelFor(model => model.applicationNumber)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.applicationNumber)
@Html.ValidationMessageFor(model => model.applicationNumber)
</div>
<div class="editor-label">
@Html.LabelFor(model => model.startNumber)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.startNumber)
@Html.ValidationMessageFor(model => model.startNumber)
</div>
<div class="editor-label">
@Html.LabelFor(model => model.startSequence)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.startSequence)
@Html.ValidationMessageFor(model => model.startSequence)
</div>
<div class="editor-label">
@Html.LabelFor(model => model.permitType)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.permitType)
@Html.ValidationMessageFor(model => model.permitType)
</div>
<div class="editor-label">
@Html.LabelFor(model => model.permitSequence)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.permitSequence)
@Html.ValidationMessageFor(model => model.permitSequence)
</div>
<div class="editor-label">
@Html.LabelFor(model => model.inspectionType)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.inspectionType)
@Html.ValidationMessageFor(model => model.inspectionType)
</div>
<div class="editor-label">
@Html.LabelFor(model => model.inspectionSequence)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.inspectionSequence)
@Html.ValidationMessageFor(model => model.inspectionSequence)
</div>
<p>
<input type="submit" value="Submit"/>
</p>
</fieldset>
}
@section Scripts {
@Scripts.Render("~/bundles/jqueryval")
}
using System;
using System.Collections.Specialized;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using FusionServiceHelper.Models;
// NOTE: Replace 'MyController' with the name of your controller.
//
// GET: /MyController/PostCancelInspection
public ActionResult PostCancelInspection()
{
// Create a new instance of the model to pick up any default values.
PostCancelInspection model = new PostCancelInspection();
// pass model to set to default values
// NOTE: Change 'MyFolderPath' to the path to the .cshtml file.
return View("~/Views/MyFolderPath/PostCancelInspection.cshtml", model);
}
//
// POST: /MyController/PostCancelInspection
[HttpPost]
public ActionResult PostCancelInspection(FormCollection collection)
{
string url = "v3/Naviline/Inspection/Cancel";
// Get the value from each input field
NameValueCollection inputParms = new NameValueCollection();
inputParms.Add("applicationYear", collection["applicationYear"]);
inputParms.Add("applicationNumber", collection["applicationNumber"]);
inputParms.Add("startNumber", collection["startNumber"]);
inputParms.Add("startSequence", collection["startSequence"]);
inputParms.Add("permitType", collection["permitType"]);
inputParms.Add("permitSequence", collection["permitSequence"]);
inputParms.Add("inspectionType", collection["inspectionType"]);
inputParms.Add("inspectionSequence", collection["inspectionSequence"]);
try
{
// Send the request
FusionServiceRequest request = new FusionServiceRequest();
FusionServiceResult result = request.Post(url, inputParms);
return View("Result", result);
}
catch(Exception e)
{
HandleErrorInfo info = new HandleErrorInfo(e, "MyController", "PostCancelInspection");
return View("Error", info);
}
}