mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
Merge branch '3'
This commit is contained in:
commit
a5da085cc7
@ -134,7 +134,7 @@ class LeftAndMain extends Controller implements PermissionProvider
|
||||
* @config
|
||||
* @var string
|
||||
*/
|
||||
private static $help_link = '//userhelp.silverstripe.org/framework/en/3.3';
|
||||
private static $help_link = '//userhelp.silverstripe.org/framework/en/3.5';
|
||||
|
||||
/**
|
||||
* @var array
|
||||
@ -1345,8 +1345,7 @@ class LeftAndMain extends Controller implements PermissionProvider
|
||||
}
|
||||
|
||||
$link = Controller::join_links($recordController->Link("show"), $record->ID);
|
||||
$html = LeftAndMain_TreeNode::create($record, $link, $this->isCurrentPage($record))
|
||||
->forTemplate() . '</li>';
|
||||
$html = LeftAndMain_TreeNode::create($record, $link, $this->isCurrentPage($record))->forTemplate() ;
|
||||
|
||||
$data[$id] = array(
|
||||
'html' => $html,
|
||||
|
@ -2,6 +2,7 @@
|
||||
|
||||
namespace SilverStripe\Admin;
|
||||
|
||||
use SilverStripe\View\SSViewer;
|
||||
use SilverStripe\View\ViewableData;
|
||||
|
||||
/**
|
||||
@ -76,17 +77,26 @@ class LeftAndMain_TreeNode extends ViewableData
|
||||
*
|
||||
* @todo Remove hardcoded assumptions around returning an <li>, by implementing recursive tree node rendering
|
||||
*
|
||||
* @return String
|
||||
* @return string
|
||||
*/
|
||||
public function forTemplate()
|
||||
{
|
||||
$obj = $this->obj;
|
||||
return "<li id=\"record-$obj->ID\" data-id=\"$obj->ID\" data-pagetype=\"$obj->ClassName\" class=\""
|
||||
. $this->getClasses() . "\">" . "<ins class=\"jstree-icon\"> </ins>"
|
||||
. "<a href=\"" . $this->getLink() . "\" title=\"("
|
||||
. trim(_t('LeftAndMain.PAGETYPE', 'Page type'), " :") // account for inconsistencies in translations
|
||||
. ": " . $obj->i18n_singular_name() . ") $obj->Title\" ><ins class=\"jstree-icon\"> </ins><span class=\"text\">" . ($obj->TreeTitle)
|
||||
. "</span></a>";
|
||||
|
||||
return (string)SSViewer::execute_template(
|
||||
'SilverStripe\\Admin\\Includes\\LeftAndMain_TreeNode',
|
||||
$obj,
|
||||
array(
|
||||
'Classes' => $this->getClasses(),
|
||||
'Link' => $this->getLink(),
|
||||
'Title' => sprintf(
|
||||
'(%s: %s) %s',
|
||||
trim(_t('LeftAndMain.PAGETYPE', 'Page type'), " :"),
|
||||
$obj->i18n_singular_name(),
|
||||
$obj->Title
|
||||
),
|
||||
)
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
@ -118,7 +128,7 @@ class LeftAndMain_TreeNode extends ViewableData
|
||||
}
|
||||
$classes .= ' ' . $filterClasses;
|
||||
}
|
||||
return $classes;
|
||||
return $classes ?: '';
|
||||
}
|
||||
|
||||
public function getObj()
|
||||
|
@ -0,0 +1,6 @@
|
||||
<li id="record-$ID" data-id="$ID" data-pagetype="$ClassName" class="$Classes">
|
||||
<ins class="jstree-icon"> </ins>
|
||||
<a href="$Link" title="$Title.ATT"><ins class="jstree-icon"> </ins>
|
||||
<span class="text">$TreeTitle</span>
|
||||
</a>
|
||||
</li>
|
@ -24,5 +24,6 @@ class TestObject extends DataObject implements TestOnly
|
||||
|
||||
public function CMSTreeClasses()
|
||||
{
|
||||
return '';
|
||||
}
|
||||
}
|
||||
|
@ -4,9 +4,6 @@ An easy and reliable approach to getting SilverStripe running on Windows is to u
|
||||
done through [WampServer](http://www.wampserver.com/en/). This can be useful if you are deploying on Linux Apache and
|
||||
want a Microsoft Windows machine with a very similar environment.
|
||||
|
||||
Note: Installing on Microsoft's IIS webserver through Microsoft WebPI is likely to be easier, see
|
||||
[Windows with Web Platform Installer](other_installation_options/windows_platform_installer).
|
||||
|
||||
## Install WAMP
|
||||
|
||||
1. Go to the [WampServer download page](http://www.wampserver.com/en/#download-wrapper).
|
||||
|
@ -1,50 +0,0 @@
|
||||
# Windows with Web Platform Installer (WebPI)
|
||||
|
||||
(Windows XP, 2003, 2008, Vista and 7)
|
||||
|
||||
## Installing SilverStripe
|
||||
|
||||
* Download and run Microsoft Web Platform Installer (WebPI):
|
||||
[![](http://www.silverstripe.org/assets/downloads/webpi/wpiBadgeGreen.png)](http://www.microsoft.com/web/gallery/install.aspx?appsxml=www.microsoft.com%2fweb%2fwebpi%2f2.0%2fWebApplicationList.xml&appid=105)
|
||||
|
||||
* In WebPI, select 'SilverStripe' from the 'Content Management System' link
|
||||
* Select install. It will install dependancies like MySQL and PHP if you don't have these installed already.
|
||||
* Type in the questions it asks you, such as the username/password you set in the above MySQL installation:
|
||||
* Everything should be installed, with you seeing the initial webpage
|
||||
* And you can log-in to the CMS
|
||||
|
||||
## Important: Installation issue on XP
|
||||
|
||||
After you've installed SilverStripe on XP using WebPI. You'll need to make a configuration change to get it working.
|
||||
|
||||
Specifically, you need to configure XP not to check that a script file exists before executing the script. This is
|
||||
necessary for URLs of the form http://localhost/silverstripe/index.php/about-us/ to work.
|
||||
|
||||
* Open IIS Administrator
|
||||
* Expand the local computer tree node
|
||||
* Expand the Web Sites tree node
|
||||
* Right click on "Default Web Site" and select "Properties"
|
||||
* Select the "Home Directory" Tab.
|
||||
* Click the "Configuration Button towards the bottom on the right
|
||||
* Select the "Mappings" Tab
|
||||
* Find the .php mapping, select it and click the "Edit" button
|
||||
* Make sure the check box "Check that file exists" is cleared.
|
||||
* Hit OK's all the way back up and restart IIS
|
||||
|
||||
## Support
|
||||
|
||||
* http://www.silverstripe.org/installing-on-windows-now-easier-thanks-to-microsoft-web-platform-installer/ (This shows
|
||||
a beta version of the software)
|
||||
* Microsoft Forum: http://forums.iis.net/1155.aspx
|
||||
* SilverStripe Installation Issues Forum: http://silverstripe.org/installing-silverstripe/
|
||||
|
||||
## Screenshots
|
||||
|
||||
![](../../../_images/webpi-2-a-silverstripe-choice.jpg)
|
||||
![](../../../_images/webpi-2-b-dependencies.jpg)
|
||||
![](../../../_images/webpi-2-c-downloading-and-installaing.jpg)
|
||||
![](../../../_images/webpi-2-d-installer-questions-step1.jpg)
|
||||
![](../../../_images/webpi-2-e-installer-questions-step2.jpg)
|
||||
![](../../../_images/webpi-2-f-success-message.jpg)
|
||||
![](../../../_images/webpi-2-g-silverstripe-homepage.jpg)
|
||||
![](../../../_images/webpi-2-h-cms-interface-working.jpg)
|
14
docs/en/04_Changelogs/rc/3.4.4-rc1.md
Normal file
14
docs/en/04_Changelogs/rc/3.4.4-rc1.md
Normal file
@ -0,0 +1,14 @@
|
||||
# 3.4.4-rc1
|
||||
|
||||
<!--- Changes below this line will be automatically regenerated -->
|
||||
|
||||
## Change Log
|
||||
|
||||
### Security
|
||||
|
||||
* 2017-01-13 [c6c6c13](https://github.com/silverstripe/silverstripe-framework/commit/c6c6c13fc265aeedf5de7226b3cde39d185ba49d) Unescaped title attribute in LeftAndMain_TreeNode::forTemplate (Daniel Hensby) - See [ss-2017-001](http://www.silverstripe.org/download/security-releases/ss-2017-001)
|
||||
|
||||
### Bugfixes
|
||||
|
||||
* 2017-01-16 [17d123a](https://github.com/silverstripe/silverstripe-framework/commit/17d123a3be3a2c9e21845fda89c61f00301f78f5) Ensure correct regeneration of ConfigManifest if only one of the cache files is missing (Stephan Bauer)
|
||||
* 2017-01-10 [5bba726](https://github.com/silverstripe/silverstripe-cms/commit/5bba7264c69b654ac5bcb87769781138be61cb92) Dont attempt to iterate over null in SiteTree::allowedChildren (Daniel Hensby)
|
17
docs/en/04_Changelogs/rc/3.5.2-rc1.md
Normal file
17
docs/en/04_Changelogs/rc/3.5.2-rc1.md
Normal file
@ -0,0 +1,17 @@
|
||||
# 3.5.2-rc1
|
||||
|
||||
<!--- Changes below this line will be automatically regenerated -->
|
||||
|
||||
## Change Log
|
||||
|
||||
### Security
|
||||
|
||||
* 2017-01-13 [c6c6c13](https://github.com/silverstripe/silverstripe-framework/commit/c6c6c13fc265aeedf5de7226b3cde39d185ba49d) Unescaped title attribute in LeftAndMain_TreeNode::forTemplate (Daniel Hensby) - See [ss-2017-001](http://www.silverstripe.org/download/security-releases/ss-2017-001)
|
||||
|
||||
### Bugfixes
|
||||
|
||||
* 2017-01-24 [c640ade](https://github.com/silverstripe/silverstripe-framework/commit/c640ade9112c703068754c7d7061d646da7307bd) ed iframe postmessage breaking non-string messages (Ruud Arentsen)
|
||||
* 2017-01-16 [17d123a](https://github.com/silverstripe/silverstripe-framework/commit/17d123a3be3a2c9e21845fda89c61f00301f78f5) Ensure correct regeneration of ConfigManifest if only one of the cache files is missing (Stephan Bauer)
|
||||
* 2017-01-14 [1f1fffe](https://github.com/silverstripe/silverstripe-framework/commit/1f1fffe73454930c1aef394e9b106a484e6d59ee) Ensure correct regeneration of ConfigManifest if only one of the cache files is missing (fixes #6467) (Stephan Bauer)
|
||||
* 2017-01-10 [5bba726](https://github.com/silverstripe/silverstripe-cms/commit/5bba7264c69b654ac5bcb87769781138be61cb92) Dont attempt to iterate over null in SiteTree::allowedChildren (Daniel Hensby)
|
||||
* 2016-12-21 [f314b86](https://github.com/silverstripe/silverstripe-framework/commit/f314b86ad804b021cda255e4645e99e8d971fa8a) Temp disable shortcode SPLIT behaviour due to crash (#6436) (Damian Mooyman)
|
@ -357,36 +357,11 @@ will need to be regularly updated.
|
||||
forum category. Make this a global read-only sticky, and un-sticky any older release.
|
||||
* Update the #silverstripe [IRC](https://www.silverstripe.org/community/contributing-to-silverstripe/irc-channel/) topic to include the new release version.
|
||||
|
||||
### Stage 4: Web platform installer release
|
||||
|
||||
The web platform installer is available [on the web app gallery](http://www.microsoft.com/web/gallery/silverstripecms.aspx).
|
||||
|
||||
In order to update this you will need a Microsoft live account, and have it authorised
|
||||
by SilverStripe staff in order to publish these releases.
|
||||
|
||||
|
||||
To update this release there is an additional download tool at
|
||||
`[https://code.platform.silverstripe.com/silverstripe/webpi](https://code.platform.silverstripe.com/silverstripe/webpi)`
|
||||
which will guide you through the process of generating a new zip release.
|
||||
|
||||
./make-package 3.2.4 3.2.4
|
||||
aws s3 cp ./silverstripe-3.2.4-webpi.zip s3://silverstripe-ssorg-releases/sssites-ssorg-prod/assets/downloads/webpi/silverstripe-3.2.4-webpi.zip --acl public-read --profile silverstripe
|
||||
|
||||
Once you have a new release, update the necessary details at
|
||||
[http://www.microsoft.com/web/gallery/appsubmit.aspx?id=57](http://www.microsoft.com/web/gallery/appsubmit.aspx?id=57)
|
||||
to submit a new version, including:
|
||||
|
||||
* Set the version number
|
||||
* Update the release date
|
||||
* Submit the package URL
|
||||
* Submit the package SHA
|
||||
|
||||
## See also
|
||||
|
||||
* [Release Process](release_process)
|
||||
* [Translation Process](translation_process)
|
||||
* [Core committers](core_committers)
|
||||
* [WebPI Installer](https://docs.silverstripe.org/en/getting_started/installation/other_installation_options/windows_platform_installer/)
|
||||
|
||||
If at any time a release runs into an unsolveable problem contact the
|
||||
core committers on the [discussion group](https://groups.google.com/forum/#!forum/silverstripe-committers)
|
||||
|
@ -147,26 +147,29 @@ class Convert
|
||||
}
|
||||
|
||||
/**
|
||||
* Encode a value as a JSON encoded string.
|
||||
* Encode a value as a JSON encoded string. You can optionally pass a bitmask of
|
||||
* JSON constants as options through to the encode function.
|
||||
*
|
||||
* @param mixed $val Value to be encoded
|
||||
* @param int $options Optional bitmask of JSON constants
|
||||
* @return string JSON encoded string
|
||||
*/
|
||||
public static function raw2json($val)
|
||||
public static function raw2json($val, $options = 0)
|
||||
{
|
||||
return json_encode($val);
|
||||
return json_encode($val, $options);
|
||||
}
|
||||
|
||||
/**
|
||||
* Encode an array as a JSON encoded string.
|
||||
* THis is an alias to {@link raw2json()}
|
||||
* This is an alias to {@link raw2json()}
|
||||
*
|
||||
* @param array $val Array to convert
|
||||
* @param int $options Optional bitmask of JSON constants
|
||||
* @return string JSON encoded string
|
||||
*/
|
||||
public static function array2json($val)
|
||||
public static function array2json($val, $options = 0)
|
||||
{
|
||||
return self::raw2json($val);
|
||||
return self::raw2json($val, $options);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -88,7 +88,11 @@ class CsvBulkLoader extends BulkLoader
|
||||
@unlink($file);
|
||||
}
|
||||
} catch (Exception $e) {
|
||||
print "Failed to parse {$last}\n";
|
||||
$failedMessage = sprintf("Failed to parse %s", $last);
|
||||
if (Director::isDev()) {
|
||||
$failedMessage = sprintf($failedMessage . " because %s", $e->getMessage());
|
||||
}
|
||||
print $failedMessage . PHP_EOL;
|
||||
}
|
||||
|
||||
return $result;
|
||||
|
@ -149,7 +149,7 @@ class Hierarchy extends DataExtension
|
||||
*/
|
||||
public function getChildrenAsUL(
|
||||
$attributes = "",
|
||||
$titleEval = '"<li>" . $child->Title',
|
||||
$titleEval = '"<li>" . $child->Title . "</li>"',
|
||||
$extraArg = null,
|
||||
$limitToMarked = false,
|
||||
$childrenMethod = "AllChildrenIncludingDeleted",
|
||||
@ -202,6 +202,10 @@ class Hierarchy extends DataExtension
|
||||
} else {
|
||||
$output .= eval("return $titleEval;");
|
||||
}
|
||||
$output = trim($output);
|
||||
if (substr($output, -5) == '</li>') {
|
||||
$output = trim(substr($output, 0, -5));
|
||||
}
|
||||
$output .= "\n";
|
||||
|
||||
$numChildren = $child->$numChildrenMethod();
|
||||
|
@ -368,6 +368,20 @@ PHP
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Test that a context bitmask can be passed through to the json_encode method in {@link Convert::raw2json()}
|
||||
* and in {@link Convert::array2json()}
|
||||
*/
|
||||
public function testRaw2JsonWithContext()
|
||||
{
|
||||
$data = array('foo' => 'b"ar');
|
||||
$expected = '{"foo":"b\u0022ar"}';
|
||||
$result = Convert::raw2json($data, JSON_HEX_QUOT);
|
||||
$this->assertSame($expected, $result);
|
||||
$wrapperResult = Convert::array2json($data, JSON_HEX_QUOT);
|
||||
$this->assertSame($expected, $wrapperResult);
|
||||
}
|
||||
|
||||
/**
|
||||
* Tests {@link Convert::xml2array()}
|
||||
*/
|
||||
|
@ -30,8 +30,8 @@ class TreeDropdownFieldTest extends SapphireTest
|
||||
$cssPath = 'ul.tree li#selector-TestTree-'.$folder1->ID.' li#selector-TestTree-'.$folder1Subfolder1->ID.' a span.item';
|
||||
$firstResult = $parser->getBySelector($cssPath);
|
||||
$this->assertEquals(
|
||||
(string)$firstResult[0],
|
||||
$folder1Subfolder1->Name,
|
||||
(string)$firstResult[0],
|
||||
$folder1Subfolder1->Name.' is found, nested under '.$folder1->Name
|
||||
);
|
||||
|
||||
@ -39,8 +39,8 @@ class TreeDropdownFieldTest extends SapphireTest
|
||||
$cssPath = 'ul.tree li#selector-TestTree-'.$subfolder->ID.' a span.item';
|
||||
$secondResult = $parser->getBySelector($cssPath);
|
||||
$this->assertEquals(
|
||||
(string)$secondResult[0],
|
||||
$subfolder->Name,
|
||||
(string)$secondResult[0],
|
||||
$subfolder->Name.' is found at root level'
|
||||
);
|
||||
|
||||
@ -48,9 +48,8 @@ class TreeDropdownFieldTest extends SapphireTest
|
||||
$folder2 = $this->objFromFixture(Folder::class, 'folder2');
|
||||
$cssPath = 'ul.tree li#selector-TestTree-'.$folder2->ID.' a span.item';
|
||||
$noResult = $parser->getBySelector($cssPath);
|
||||
$this->assertEquals(
|
||||
$this->assertEmpty(
|
||||
$noResult,
|
||||
array(),
|
||||
$folder2.' is not found'
|
||||
);
|
||||
|
||||
@ -66,8 +65,8 @@ class TreeDropdownFieldTest extends SapphireTest
|
||||
$cssPath = 'ul.tree li#selector-TestTree-'.$folder1->ID.' li#selector-TestTree-'.$folder1Subfolder1->ID.' a span.item';
|
||||
$firstResult = $parser->getBySelector($cssPath);
|
||||
$this->assertEquals(
|
||||
(string)$firstResult[0],
|
||||
$folder1Subfolder1->Name,
|
||||
(string)$firstResult[0],
|
||||
$folder1Subfolder1->Name.' is found, nested under '.$folder1->Name
|
||||
);
|
||||
|
||||
@ -76,27 +75,25 @@ class TreeDropdownFieldTest extends SapphireTest
|
||||
$file2 = $this->objFromFixture(File::class, 'subfolderfile2');
|
||||
$cssPath = 'ul.tree li#selector-TestTree-'.$subfolder->ID.' li#selector-TestTree-'.$file1->ID.' a';
|
||||
$firstResult = $parser->getBySelector($cssPath);
|
||||
$this->assertGreaterThan(
|
||||
0,
|
||||
count($firstResult),
|
||||
$this->assertNotEmpty(
|
||||
$firstResult,
|
||||
$file1->Name.' with ID '.$file1->ID.' is in search results'
|
||||
);
|
||||
$this->assertEquals(
|
||||
(string)$firstResult[0],
|
||||
$file1->Name,
|
||||
(string)$firstResult[0],
|
||||
$file1->Name.' is found nested under '.$subfolder->Name
|
||||
);
|
||||
|
||||
$cssPath = 'ul.tree li#selector-TestTree-'.$subfolder->ID.' li#selector-TestTree-'.$file2->ID.' a';
|
||||
$secondResult = $parser->getBySelector($cssPath);
|
||||
$this->assertGreaterThan(
|
||||
0,
|
||||
count($secondResult),
|
||||
$this->assertNotEmpty(
|
||||
$secondResult,
|
||||
$file2->Name.' with ID '.$file2->ID.' is in search results'
|
||||
);
|
||||
$this->assertEquals(
|
||||
(string)$secondResult[0],
|
||||
$file2->Name,
|
||||
(string)$secondResult[0],
|
||||
$file2->Name.' is found nested under '.$subfolder->Name
|
||||
);
|
||||
|
||||
@ -104,9 +101,8 @@ class TreeDropdownFieldTest extends SapphireTest
|
||||
$file3 = $this->objFromFixture(File::class, 'asdf');
|
||||
$cssPath = 'ul.tree li#selector-TestTree-'.$file3->ID;
|
||||
$noResult = $parser->getBySelector($cssPath);
|
||||
$this->assertEquals(
|
||||
$this->assertEmpty(
|
||||
$noResult,
|
||||
array(),
|
||||
$file3->Name.' is not found'
|
||||
);
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user