本文整理汇总了C#中iSolutions.iApply.DataContract.Application类的典型用法代码示例。如果您正苦于以下问题:C# Application类的具体用法?C# Application怎么用?C# Application使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
Application类属于iSolutions.iApply.DataContract命名空间,在下文中一共展示了Application类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: AdministratorDefaultToWriteAccess
public void AdministratorDefaultToWriteAccess()
{
Application application = new Application
{
FormId = "form-1",
OrganisationId = "org-1",
WorkflowState = "New"
};
User user = new User
{
Id = "administrator-1",
Roles = new Dictionary<string, string> { { "role-1", "role-1" }, { "Administrators", "Administrators" } }
};
user.Organisations.Add("org-1", "Organisation One");
var controlsList = new ControlList
{
new TextControl { Id = 1 }
};
AccessLevel applicationAccess = this.provider.GetApplicationAccess(new SecureSession(user), application, this.roleList, 1);
List<ControlAccess> controlsAccess = this.provider.GetControlsAccess(new SecureSession(user), application, controlsList, this.roleList, 1);
Assert.AreEqual(AccessLevel.Write, applicationAccess);
Assert.AreEqual(AccessLevel.Write, controlsAccess[0].AccessLevel);
}
示例2: Map
/// <summary>
/// Populates <paramref name="target"/> with static and <paramref name="source"/> values
/// as defined by <paramref name="fieldMap"/>.
/// </summary>
/// <param name="source">The application from which to get field values.</param>
/// <param name="fieldMap">A definition of field mappings.</param>
/// <param name="target">The target object to populate with mapped key/values.</param>
internal void Map(Application source, MappedFieldList fieldMap, JObject target)
{
foreach (MappedField map in fieldMap)
{
switch (map.MapType)
{
case MapType.Value:
case MapType.PrivateValue:
target.Add(map.Target, map.Source);
break;
case MapType.Field:
object tokenValue = source.GetTokenValue(map.Source);
if (tokenValue == null)
{
target.Add(map.Target, string.Empty);
}
else if (tokenValue is IEnumerable<object>)
{
target.Add(map.Target, JArray.FromObject(tokenValue));
}
else
{
target.Add(map.Target, tokenValue.ToString());
}
break;
default:
throw new InvalidOperationException(string.Format(ExceptionMessages.InvalidMapType, map.MapType));
}
}
}
示例3: GetDataPropertyValueUnknownToken
public void GetDataPropertyValueUnknownToken()
{
Application application = new Application();
object value = application.GetTokenValue("Foo");
Assert.IsNull(value);
}
示例4: AccessNewApplication
public void AccessNewApplication()
{
ApplicationEntitlementProvider wrappedProvider = new ApplicationEntitlementProvider(new MockSecurityService());
FormPreviewApplicationEntitlementProvider provider = new FormPreviewApplicationEntitlementProvider(wrappedProvider)
{
ImpersonatedSession = new ImpersonatedSession(new Dictionary<string, string>
{
{ "role-2", "role-2" }
})
};
Application application = new Application
{
FormId = "form-1",
OrganisationId = "org-1",
WorkflowState = "New"
};
User user = new User
{
Id = "user-1",
Roles = new Dictionary<string, string>
{ { "role-1", "role-1" } }
};
user.Organisations.Add("org-1", "Organisation One");
AccessLevel applicationAccess = provider.GetApplicationAccess(new SecureSession(user), application, this.roleList, 1);
Assert.AreEqual(AccessLevel.Write, applicationAccess);
}
示例5: GetApplicationAccess
/// <summary>
/// Gets the base <see cref="AccessLevel" /> applicable for a combination of user & application.
/// </summary>
/// <param name="session">Contains session and user information used to determine access rights.</param>
/// <param name="application">The application.</param>
/// <param name="roleList">The list of roles.</param>
/// <param name="versionNumber">The version number of the form being accessed.</param>
/// <returns>The base <see cref="AccessLevel" /> applicable for a combination of user & application.</returns>
public virtual AccessLevel GetApplicationAccess(SecureSession session, Application application, RoleList roleList, int versionNumber)
{
if (this.IsAdministrator(session))
{
return AccessLevel.Write;
}
if (!this.IsOrganisationEntitled(session, application))
{
return AccessLevel.NoAccess;
}
string userId = this.GetSessionUserId(session);
bool viewAllDrafts = session.AuthenticatedUser != null && this.GetSystemEntitlements(userId)[SystemEntitlementAccess.VIEW_DRAFT_APPLICATIONS] > AccessLevel.NoAccess;
if (application.Draft && application.AssignedTo != userId && !viewAllDrafts)
{
return AccessLevel.NoAccess;
}
var systemEntitlements = this.GetSystemEntitlements(session.AuthenticatedUser != null ? session.AuthenticatedUser.Id : null);
if (application.Draft && application.AssignedTo != userId && systemEntitlements[SystemEntitlementAccess.VIEW_DRAFT_APPLICATIONS] == AccessLevel.NoAccess)
{
return AccessLevel.NoAccess;
}
Dictionary<string, string> userRoles = this.DetermineRolesForUser(session, roleList, application);
ApplicationEntitlementList applicationEntitlements = this.securityService.GetApplicationEntitlements(application.FormId, versionNumber, application.WorkflowState, userRoles.Keys);
return applicationEntitlements.Any() ? applicationEntitlements.Max(e => e.AccessLevel) : AccessLevel.NoAccess;
}
示例6: GetClassPropertyValueNull
public void GetClassPropertyValueNull()
{
Application application = new Application();
object value = application.GetTokenValue("ApplicationId");
Assert.IsNull(value);
}
示例7: ApplicationUrl
public void ApplicationUrl()
{
Application application = new Application { ApplicationId = "4kdlsjfdlsfjldsads" };
this.formatter.BaseUrl = @"http://core.iapply.web";
string replaced = this.formatter.Format(@"{%ApplicationUrl%}", application, new ControlList());
string testUrl = string.Format("{0}/#/form/{1}/app/{2}", this.formatter.BaseUrl, application.FormId, application.ApplicationId);
Assert.AreEqual(string.Format("<a href=\"{0}\">{0}</a>", testUrl), replaced);
}
示例8: GetDataPropertyValue
public void GetDataPropertyValue()
{
Application application = new Application();
application.ApplicationData.Add("Foo", "Bar");
string value = application.GetTokenValue("Foo").ToString();
Assert.AreEqual("Bar", value);
}
示例9: GetDataPropertyValueNull
public void GetDataPropertyValueNull()
{
Application application = new Application();
application.ApplicationData.Add("Foo", null);
object value = application.GetTokenValue("Foo");
Assert.IsNull(value);
}
示例10: DateTimeStamp
public void DateTimeStamp()
{
Application application = new Application { OrganisationId = "MyOrg!", ApplicationId = "4kdlsjfdlsfjldsads" };
string replaced = this.formatter.Format(@"Example\Path\Docs\{%OrganisationId%}_{%ApplicationId%}_{%Timestamp[yyyyMMdd-HHmmss]%}.pdf", application, new ControlList());
string date = DateTime.Now.ToString("yyyyMMdd-HHmmss");
Assert.AreEqual(@"Example\Path\Docs\MyOrg!_4kdlsjfdlsfjldsads_" + date + ".pdf", replaced);
}
示例11: ApplicationWorkflowItem
/// <summary>
/// Initializes a new instance of the <see cref="ApplicationWorkflowItem"/> class.
/// </summary>
/// <param name="postedApplication">The updated <see cref="Application"/> containing
/// the posted <see cref="ApplicationData"/>.</param>
/// <param name="existingData">The existing <see cref="ApplicationData"/>. Defaults to <see langword="null"/>.</param>
/// <param name="controlList">The controls. Defaults to <see langword="null"/>.</param>
public ApplicationWorkflowItem(Application postedApplication, ApplicationData existingData = null, ControlList controlList = null)
: this(postedApplication.FormId, postedApplication.LastEditBy)
{
this.ApplicationId = postedApplication.ApplicationId;
this.VersionNumber = postedApplication.VersionNumber;
this.PostedData = postedApplication.ApplicationData;
this.ExistingData = existingData;
this.ControlList = controlList;
}
示例12: GetApplicationAccess
/// <summary>
/// Gets the base <see cref="AccessLevel" /> applicable for a combination of user & application.
/// </summary>
/// <param name="session">Contains session and user information used to determine access rights.</param>
/// <param name="application">The application.</param>
/// <param name="roleList">The list of roles.</param>
/// <param name="versionNumber">The version number of the form being accessed.</param>
/// <returns>The base <see cref="AccessLevel" /> applicable for a combination of user & application.</returns>
public AccessLevel GetApplicationAccess(SecureSession session, Application application, RoleList roleList, int versionNumber)
{
if (this.ImpersonatedSession != null && string.IsNullOrWhiteSpace(application.Id))
{
this.ImpersonateEntitlements(session);
}
return this.wrappedProvider.GetApplicationAccess(session, application, roleList, versionNumber);
}
示例13: GetClassPropertyValue
public void GetClassPropertyValue()
{
Application application = new Application
{
ApplicationId = "GetMe"
};
string value = application.GetTokenValue("ApplicationId").ToString();
Assert.AreEqual("GetMe", value);
}
示例14: ApplicationDataValueNotFound
public void ApplicationDataValueNotFound()
{
Application application = new Application { OrganisationId = "MyOrg!", ApplicationId = "4kdlsjfdlsfjldsads" };
application.ApplicationData.Add("key1", "someval");
application.ApplicationData.Add("key2", 456);
application.ApplicationData.Add("key3", false);
string replaced = this.formatter.Format(@"Example\Path\Docs\{%OrganisationId%}_{%ApplicationId%}_{%Timestamp[yyyyMMdd]%}_{%keyunknown%}.pdf", application, new ControlList());
string date = DateTime.Now.ToString("yyyyMMdd");
Assert.AreEqual(@"Example\Path\Docs\MyOrg!_4kdlsjfdlsfjldsads_" + date + "_.pdf", replaced);
}
示例15: CreateGetRequest
/// <summary>
/// Creates and returns a GET request.
/// </summary>
/// <param name="baseUrl">The base URL, to which QueryString parameters will be appended.</param>
/// <param name="application">The application.</param>
/// <param name="requestFieldMap">The list of request fields to map.</param>
/// <param name="obfuscatedRequestBody">The request body.</param>
/// <returns>A new <see cref="HttpWebRequest" /> that uses the GET method.</returns>
private HttpWebRequest CreateGetRequest(string baseUrl, Application application, MappedFieldList requestFieldMap, out string obfuscatedRequestBody)
{
Dictionary<string, string> parameterData = this.GetHttpVariableRequestContent(application, requestFieldMap);
string url = new UrlBuilder().Create(baseUrl, parameterData);
Uri myUri = new Uri(url);
obfuscatedRequestBody = this.ObfuscateRequest(myUri.Query, HttpResources.HttpRequestFieldValueLocator, requestFieldMap);
HttpWebRequest request = (HttpWebRequest)WebRequest.Create(url);
request.Method = WebRequestMethods.Http.Get;
return request;
}