mirror of
https://github.com/OrchardCMS/Orchard.git
synced 2025-10-15 19:54:57 +08:00
Merge branch '1.8.x' into 1.x
This commit is contained in:
@@ -3,6 +3,7 @@ using System.Collections.Concurrent;
|
||||
using System.Collections.Generic;
|
||||
using System.Globalization;
|
||||
using System.Linq;
|
||||
using System.Reflection;
|
||||
using Microsoft.ApplicationServer.Caching;
|
||||
using Orchard.Azure.Services.Environment.Configuration;
|
||||
using Orchard.Caching;
|
||||
@@ -122,12 +123,27 @@ namespace Orchard.Azure.Services.Caching.Output {
|
||||
return function.Invoke();
|
||||
}
|
||||
catch (DataCacheException) {
|
||||
DataCacheFactory cacheFactory;
|
||||
Logger.Debug("Retrying cache operation");
|
||||
if (_dataCacheFactories.TryRemove(CacheConfiguration, out cacheFactory)) {
|
||||
cacheFactory.Dispose();
|
||||
// applying http://blogs.msdn.com/b/cie/archive/2014/04/29/cache-retry-fails-what-next.aspx
|
||||
try {
|
||||
DataCacheFactory cacheFactory;
|
||||
Logger.Debug("Retrying cache operation");
|
||||
if (_dataCacheFactories.TryRemove(CacheConfiguration, out cacheFactory)) {
|
||||
lock (_dataCacheFactories) {
|
||||
cacheFactory.Dispose();
|
||||
// Clear DataCacheFactory._connectionPool
|
||||
var coreAssembly = typeof(DataCacheItem).Assembly;
|
||||
var simpleSendReceiveModulePoolType = coreAssembly.
|
||||
GetType("Microsoft.ApplicationServer.Caching.SimpleSendReceiveModulePool", throwOnError: true);
|
||||
var connectionPoolField = typeof(DataCacheFactory).GetField("_connectionPool", BindingFlags.Static | BindingFlags.NonPublic);
|
||||
connectionPoolField.SetValue(null, Activator.CreateInstance(simpleSendReceiveModulePoolType));
|
||||
}
|
||||
}
|
||||
return Retry(function, times--);
|
||||
}
|
||||
catch (Exception e) {
|
||||
Logger.Error(e, "An unexpected error occured while releasing a DataCacheFactory.");
|
||||
return default(T);
|
||||
}
|
||||
return Retry(function, times--);
|
||||
}
|
||||
}
|
||||
|
||||
|
@@ -7,6 +7,7 @@ using Orchard.ContentManagement.Handlers;
|
||||
using Orchard.Localization;
|
||||
using Orchard.Logging;
|
||||
using Orchard.Security;
|
||||
using System.Configuration;
|
||||
|
||||
namespace Orchard.Email.Handlers {
|
||||
[UsedImplicitly]
|
||||
@@ -47,6 +48,8 @@ namespace Orchard.Email.Handlers {
|
||||
var encryptedPassword = String.IsNullOrWhiteSpace(value) ? String.Empty : Convert.ToBase64String(_encryptionService.Encode(Encoding.UTF8.GetBytes(value)));
|
||||
part.Store(x => x.Password, encryptedPassword);
|
||||
});
|
||||
|
||||
part.AddressPlaceholderField.Loader(value => (string)((dynamic)ConfigurationManager.GetSection("system.net/mailSettings/smtp")).From);
|
||||
}
|
||||
|
||||
public Localizer T { get; set; }
|
||||
|
@@ -19,6 +19,10 @@ namespace Orchard.Email.Models {
|
||||
set { this.Store(x => x.Address, value); }
|
||||
}
|
||||
|
||||
private readonly LazyField<string> _addressPlaceholder = new LazyField<string>();
|
||||
internal LazyField<string> AddressPlaceholderField { get { return _addressPlaceholder; } }
|
||||
public string AddressPlaceholder { get { return _addressPlaceholder.Value; } }
|
||||
|
||||
public string Host {
|
||||
get { return this.Retrieve(x => x.Host); }
|
||||
set { this.Store(x => x.Host, value); }
|
||||
|
@@ -1,17 +1,14 @@
|
||||
@using System.Configuration
|
||||
@using System.Net.Mail
|
||||
@using System.Net.Mail
|
||||
@model Orchard.Email.Models.SmtpSettingsPart
|
||||
@{
|
||||
var smtpClient = new SmtpClient();
|
||||
|
||||
dynamic section = ConfigurationManager.GetSection("system.net/mailSettings/smtp");
|
||||
}
|
||||
|
||||
<fieldset>
|
||||
<legend>@T("Email")</legend>
|
||||
<div>
|
||||
<label for="@Html.FieldIdFor(m => m.Address)">@T("Sender email address")</label>
|
||||
@Html.TextBoxFor(m => m.Address, new { @class = "text medium", placeholder = (string) section.From })
|
||||
@Html.TextBoxFor(m => m.Address, new { @class = "text medium", placeholder = Model.AddressPlaceholder })
|
||||
@Html.ValidationMessage("Address", "*")
|
||||
<span class="hint">@T("The default email address to use as a sender.")</span>
|
||||
</div>
|
||||
|
@@ -1,5 +1,5 @@
|
||||
table.media-library-picker tr td:nth-child(1) {
|
||||
background: url(images/move.gif) no-repeat 12px 14px;
|
||||
background: url(images/move.gif) no-repeat 12px 14px;
|
||||
cursor: move;
|
||||
}
|
||||
|
||||
@@ -34,8 +34,7 @@
|
||||
|
||||
.overlay {
|
||||
position: absolute;
|
||||
top: 70px;
|
||||
bottom: 32px;
|
||||
bottom: 20px;
|
||||
left: 0;
|
||||
width: 100%;
|
||||
background-color: black;
|
||||
@@ -50,16 +49,38 @@
|
||||
font-size: 12px;
|
||||
}
|
||||
|
||||
.media-thumbnail {
|
||||
width: 120px;
|
||||
height: 120px;
|
||||
}
|
||||
|
||||
.media-thumbnail-document {
|
||||
background-image: url('');
|
||||
background-repeat: no-repeat;
|
||||
background-position: center;
|
||||
border: 1px solid #e0e0e0;
|
||||
width: 120px;
|
||||
height: 120px;
|
||||
}
|
||||
|
||||
.media-thumbnail-o-embed {
|
||||
width: 120px;
|
||||
height: 120px;
|
||||
overflow:hidden;
|
||||
}
|
||||
}
|
||||
|
||||
.media-thumbnail-video {
|
||||
background-image: url('');
|
||||
background-repeat: no-repeat;
|
||||
background-position: center;
|
||||
border: 1px solid #e0e0e0;
|
||||
-moz-box-sizing: border-box;
|
||||
-webkit-box-sizing: border-box;
|
||||
box-sizing: border-box;
|
||||
}
|
||||
|
||||
.media-thumbnail-cloud-video {
|
||||
background-image: url('');
|
||||
background-repeat: no-repeat;
|
||||
background-position: center;
|
||||
border: 1px solid #e0e0e0;
|
||||
-moz-box-sizing: border-box;
|
||||
-webkit-box-sizing: border-box;
|
||||
box-sizing: border-box;
|
||||
}
|
||||
|
@@ -2,7 +2,7 @@
|
||||
$(function () {
|
||||
$(".select-all").click(function () {
|
||||
var $checkbox = $(this);
|
||||
var $allCheckboxes = $checkbox.parent().find(":checkbox");
|
||||
var $allCheckboxes = $checkbox.closest("ol").find(":checkbox");
|
||||
if ($checkbox.is(':checked')) {
|
||||
$allCheckboxes.prop("checked", true);
|
||||
}
|
||||
|
@@ -48,8 +48,9 @@ namespace Orchard.Roles.Activities {
|
||||
if (UserIsInRole(activityContext)) {
|
||||
yield return T("Yes");
|
||||
}
|
||||
|
||||
yield return T("No");
|
||||
else {
|
||||
yield return T("No");
|
||||
}
|
||||
}
|
||||
|
||||
private bool UserIsInRole(ActivityContext context) {
|
||||
|
@@ -9,8 +9,9 @@
|
||||
Script.Include("codemirror/mode/css/css.js");
|
||||
Script.Include("codemirror/mode/htmlmixed/htmlmixed.js");
|
||||
Script.Include("codemirror/mode/htmlembedded/htmlembedded.js");
|
||||
Script.Include("template-editor.js", "template-editor.min.js");
|
||||
Script.Include("template-editor.js");
|
||||
}
|
||||
|
||||
<fieldset>
|
||||
<div>
|
||||
@Html.LabelFor(m => m.Name, T("Name"))
|
||||
|
@@ -9,7 +9,7 @@
|
||||
Script.Include("codemirror/mode/css/css.js");
|
||||
Script.Include("codemirror/mode/htmlmixed/htmlmixed.js");
|
||||
Script.Include("codemirror/mode/htmlembedded/htmlembedded.js");
|
||||
Script.Include("template-editor.js", "template-editor.min.js");
|
||||
Script.Include("template-editor.js");
|
||||
}
|
||||
<fieldset>
|
||||
<div>
|
||||
|
@@ -40,7 +40,7 @@ namespace Orchard.Workflows.Tokens {
|
||||
contentItemId = workflowContext.Content.Id;
|
||||
}
|
||||
|
||||
var url = "~/Orchard.Workflows/Signal/Trigger?nonce=" + HttpUtility.UrlEncode(_signalService.Value.CreateNonce(contentItemId, token));
|
||||
var url = "~/Workflows/Signal/Trigger?nonce=" + HttpUtility.UrlEncode(_signalService.Value.CreateNonce(contentItemId, token));
|
||||
return new UrlHelper(_workContextAccessor.GetContext().HttpContext.Request.RequestContext).MakeAbsolute(url);
|
||||
});
|
||||
}
|
||||
|
Reference in New Issue
Block a user