-
-
Notifications
You must be signed in to change notification settings - Fork 12
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #74 from aem-design/develop
Develop
- Loading branch information
Showing
48 changed files
with
769 additions
and
201 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,160 @@ | ||
Param( | ||
#equivalent of using localhost in docker container | ||
[string]$AEM_HOST = "localhost", | ||
# TCP port SOURCE_CQ listens on | ||
[string]$AEM_PORT = "4502", | ||
# AEM Admin user for AEM_HOST | ||
[string]$AEM_USER = "admin", | ||
# AEM Admin password for AEM_HOST | ||
[string]$AEM_PASSWORD = "admin", | ||
# Server WebDav Path | ||
#$AEM_WEBDAV_PATH = "/crx/server/crx.default/jcr:root/" | ||
[string]$AEM_WEBDAV_PATH = "/crx", | ||
[string]$AEM_SCHEMA = "http", | ||
#to set additional flags if required | ||
[string]$VLT_FLAGS = "--insecure -Xmx2g", | ||
[string]$VLT_CMD = "../tools/vault-cli/bin/vlt", | ||
# Root folder name for placing content | ||
[string]$CONTENT_DESTINATION = ".\src\main\content", | ||
[string]$FILTER_FILE = "${CONTENT_DESTINATION}\META-INF\vault\filter.xml", | ||
[string]$FILTER_FILE_LOCATION = "${CONTENT_DESTINATION}\META-INF", | ||
[string[]]$ROOT_PATHS, | ||
[switch]$Silent = $false, | ||
[string]$LOG_PATH = (Resolve-Path -Path "..\logs" -Relative) | ||
) | ||
|
||
Function Format-XMLIndent | ||
{ | ||
[Cmdletbinding()] | ||
[Alias("IndentXML")] | ||
param | ||
( | ||
[Parameter(ValueFromPipeline)] | ||
[xml]$Content, | ||
[int]$Indent | ||
) | ||
|
||
# String Writer and XML Writer objects to write XML to string | ||
$StringWriter = New-Object System.IO.StringWriter | ||
$XmlWriter = New-Object System.XMl.XmlTextWriter $StringWriter | ||
|
||
# Default = None, change Formatting to Indented | ||
$xmlWriter.Formatting = "indented" | ||
|
||
# Gets or sets how many IndentChars to write for each level in | ||
# the hierarchy when Formatting is set to Formatting.Indented | ||
$xmlWriter.Indentation = $Indent | ||
|
||
$Content.WriteContentTo($XmlWriter) | ||
$XmlWriter.Flush();$StringWriter.Flush() | ||
$StringWriter.ToString() | ||
} | ||
|
||
|
||
Function GetFilterList | ||
{ | ||
[Cmdletbinding()] | ||
[Alias("filterList")] | ||
param | ||
( | ||
[Parameter(ValueFromPipeline)] | ||
[string]$FILTER_FILE = ".\src\main\content\META-INF\vault\filter.xml" | ||
) | ||
$FILTER_PATHS = [System.Collections.ArrayList]::new() | ||
|
||
$FILTER_XML = [xml](Get-Content $FILTER_FILE) | ||
$FILTER_XML_CONTENT = $FILTER_XML.SelectNodes("//workspaceFilter") | ||
$FILTER_XML_ITEMS = $FILTER_XML_CONTENT.SelectNodes('//filter') | ||
$FILTER_XML_ITEMS | ForEach-Object { | ||
[void]$FILTER_PATHS.Add($_.root) | ||
} | ||
|
||
return $FILTER_PATHS | ||
} | ||
|
||
if (-not($ROOT_PATHS)) { | ||
$ROOT_PATHS = GetFilterList | ||
} | ||
|
||
Write-Output "------- CONFIG ----------" | ||
Write-Output "AEM_SCHEMA: $AEM_SCHEMA" | ||
Write-Output "AEM_HOST: $AEM_HOST" | ||
Write-Output "AEM_PORT: $AEM_PORT" | ||
Write-Output "AEM_USER: $AEM_USER" | ||
Write-Output "CONTENT_DESTINATION: $CONTENT_DESTINATION" | ||
Write-Output "ROOT_PATHS: $ROOT_PATHS" | ||
Write-Output "FILTER_FILE: $FILTER_FILE" | ||
Write-Output "Silent: $Silent" | ||
Write-Output "VLT_FLAGS: $VLT_FLAGS" | ||
Write-Output "VLT_CMD:" | ||
|
||
$ROOT_PATHS | ForEach-Object { | ||
Write-Output "${VLT_CMD} ${VLT_FLAGS} --credentials ${AEM_USER}:****** export -v ${AEM_SCHEMA}://${AEM_HOST}:${AEM_PORT}${AEM_WEBDAV_PATH} $_ ${CONTENT_DESTINATION}" | ||
} | ||
|
||
if (-not($Silent)) | ||
{ | ||
$START = Read-Host -Prompt 'Do you want to start export with these settings? (y/n)' | ||
|
||
if ($START -ne "y") | ||
{ | ||
Write-Output "Quiting..." | ||
Exit | ||
} | ||
} | ||
|
||
Write-Output "------- START Exporting content ----------" | ||
$ROOT_PATHS_LAST = $ROOT_PATHS | Select-Object -Last 1 | ||
$ROOT_PATHS | ForEach-Object { | ||
Write-Output "START Export $_" | ||
$LOG_FILENAME = "$_".Replace("/","-") | ||
|
||
Write-Output "Remove Filer..." | ||
Copy-Item ".\src\main\content\META-INF\vault\filter-blank.xml" -Destination "$FILTER_FILE" | ||
|
||
Write-Output "Create filter for: $_" | ||
$FILTER_XML = [xml](Get-Content $FILTER_FILE) | ||
$FILTER_XML_CONTENT = $FILTER_XML.SelectNodes("//workspaceFilter") | ||
$FILTER_XML_DELETE = $FILTER_XML_CONTENT.SelectNodes('//filter') | ||
$FILTER_XML_DELETE | ForEach-Object{ | ||
$DELETE_STATUS = $FILTER_XML_CONTENT.RemoveChild($_) | ||
} | ||
$FILTER_XML_CONTENT_NEW = $FILTER_XML.CreateNode("element","filter","") | ||
$FILTER_XML_CONTENT_NEW.SetAttribute("root",$_) | ||
$FILTER_XML_CONTENT_NEW_ADD = $FILTER_XML_CONTENT.AppendChild($FILTER_XML_CONTENT_NEW) | ||
Write-Output "Saving..." | ||
$FILTER_XML.OuterXml | IndentXML -Indent 4 | Out-File $FILTER_FILE -encoding "UTF8" | ||
Write-Output "Done..." | ||
|
||
Write-Output "Running VLT..." | ||
Invoke-Expression -Command "${VLT_CMD} ${VLT_FLAGS} --credentials ${AEM_USER}:${AEM_PASSWORD} export -v ${AEM_SCHEMA}://${AEM_HOST}:${AEM_PORT}${AEM_WEBDAV_PATH} $_ ${CONTENT_DESTINATION}" | Tee-Object -FilePath "${LOG_PATH}\filevailt-export-$LOG_FILENAME.log" | ||
|
||
Write-Output "END Export $_" | ||
} | ||
|
||
Write-Output "------- END Exporting content ----------" | ||
|
||
Write-Output "------- START Updating ${FILTER_FILE} ----------" | ||
|
||
$FILTER_XML = [xml](Get-Content $FILTER_FILE) | ||
Write-Output "Removing Existing Filters..." | ||
$FILTER_XML_CONTENT = $FILTER_XML.SelectNodes("//workspaceFilter") | ||
$FILTER_XML_DELETE = $FILTER_XML_CONTENT.SelectNodes('//filter') | ||
$FILTER_XML_DELETE | ForEach-Object{ | ||
$DELETE_STATUS = $FILTER_XML_CONTENT.RemoveChild($_) | ||
} | ||
Write-Output "Adding Exported Filters..." | ||
$ROOT_PATHS | ForEach-Object { | ||
$FILTER_XML_CONTENT_NEW = $FILTER_XML.CreateNode("element","filter","") | ||
$FILTER_XML_CONTENT_NEW.SetAttribute("root",$_) | ||
$FILTER_XML_CONTENT_NEW_ADD = $FILTER_XML_CONTENT.AppendChild($FILTER_XML_CONTENT_NEW) | ||
} | ||
Write-Output "Saving..." | ||
$FILTER_XML.OuterXml | IndentXML -Indent 4 | Out-File $FILTER_FILE -encoding "UTF8" | ||
Write-Output "Done." | ||
Write-Output "------- DONE Updating ${FILTER_FILE} ----------" | ||
|
||
Write-Output "------- Revert Filter.xml ----------" | ||
git checkout HEAD src/main/content/META-INF/ | ||
git clean -fx src/main/content/META-INF | ||
Write-Output "------- Revert Filter.xml ----------" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,225 @@ | ||
Param( | ||
#equivalent of using localhost in docker container | ||
[string]$AEM_HOST = "localhost", | ||
# TCP port SOURCE_CQ listens on | ||
[string]$AEM_PORT = "4502", | ||
# AEM Admin user for AEM_HOST | ||
[string]$AEM_USER = "admin", | ||
# AEM Admin password for AEM_HOST | ||
[string]$AEM_PASSWORD = "admin", | ||
# Root folder name for placing content | ||
[string]$SOURCE_CONTENT_FOLDER = "localhost-author-export", | ||
# Server WebDav Path | ||
#$AEM_WEBDAV_PATH = "/crx/server/crx.default/jcr:root/" | ||
[string]$AEM_WEBDAV_PATH = "/crx", | ||
[string]$AEM_SCHEMA = "http", | ||
#to set additional flags if required | ||
[string]$VLT_FLAGS = "--insecure -Xmx2g", | ||
[string]$VLT_CMD = "../tools/vault-cli/bin/vlt", | ||
# Root folder name for placing content | ||
[string]$CONTENT_DESTINATION = ".\src\main\content", | ||
[string]$FILTER_FILE = "${CONTENT_DESTINATION}\META-INF\vault\filter.xml", | ||
[string]$FILTER_FILE_LOCATION = "${CONTENT_DESTINATION}\META-INF", | ||
#which filter paths to import | ||
[string[]]$ROOT_PATHS, | ||
[string]$ROOT_PATH = "/", | ||
[string]$CONTENT_SOURCE = (Resolve-Path -Path "src\main\content\jcr_root" -Relative), | ||
# connection timeout | ||
[string]$TIMEOUT = "5", | ||
# host address | ||
[string]$ADDRESS = "${AEM_SCHEMA}://${AEM_HOST}:${AEM_PORT}", | ||
# Disable services before import | ||
[string[]]$SERVICES_TO_DISABLE = @( | ||
"/system/console/bundles/com.day.cq.cq-mailer", | ||
"/system/console/bundles/com.adobe.granite.workflow.core" | ||
), | ||
|
||
[HashTable]$BODY_SERVICE_TO_DISABLE = @{ | ||
"action"="stop" | ||
}, | ||
[HashTable]$BODY_SERVICE_TO_DISABLE_ENABLE = @{ | ||
"action"="start" | ||
}, | ||
[switch]$Silent = $false, | ||
[string]$LOG_PATH = (Resolve-Path -Path "..\logs" -Relative) | ||
) | ||
|
||
|
||
Function Format-XMLIndent | ||
{ | ||
[Cmdletbinding()] | ||
[Alias("IndentXML")] | ||
param | ||
( | ||
[Parameter(ValueFromPipeline)] | ||
[xml]$Content, | ||
[int]$Indent | ||
) | ||
|
||
# String Writer and XML Writer objects to write XML to string | ||
$StringWriter = New-Object System.IO.StringWriter | ||
$XmlWriter = New-Object System.XMl.XmlTextWriter $StringWriter | ||
|
||
# Default = None, change Formatting to Indented | ||
$xmlWriter.Formatting = "indented" | ||
|
||
# Gets or sets how many IndentChars to write for each level in | ||
# the hierarchy when Formatting is set to Formatting.Indented | ||
$xmlWriter.Indentation = $Indent | ||
|
||
$Content.WriteContentTo($XmlWriter) | ||
$XmlWriter.Flush();$StringWriter.Flush() | ||
$StringWriter.ToString() | ||
} | ||
|
||
|
||
function doSlingPost { | ||
[CmdletBinding()] | ||
Param ( | ||
|
||
[Parameter(Mandatory=$true)] | ||
[string]$Url="http://localhost:4502", | ||
|
||
[Parameter(Mandatory)] | ||
[ValidateNotNullOrEmpty()] | ||
[ValidateSet('Post','Delete')] | ||
[string]$Method, | ||
|
||
[Parameter(Mandatory=$false)] | ||
[HashTable]$Body, | ||
|
||
[Parameter(Mandatory=$false, | ||
HelpMessage="Provide Basic Auth Credentials in following format: <user>:<pass>")] | ||
[string]$BasicAuthCreds="", | ||
|
||
[Parameter(Mandatory=$false)] | ||
[string]$UserAgent="", | ||
|
||
[Parameter(Mandatory=$false)] | ||
[string]$Referer="", | ||
|
||
[Parameter(Mandatory=$false)] | ||
[string]$Timeout="5" | ||
|
||
) | ||
|
||
|
||
|
||
$HEADERS = @{ | ||
} | ||
|
||
if (-not([string]::IsNullOrEmpty($UserAgent))) { | ||
$HEADERS.add("User-Agent",$UserAgent) | ||
} | ||
|
||
if (-not([string]::IsNullOrEmpty($Referer))) { | ||
$HEADERS.add("Referer",$Referer) | ||
} | ||
|
||
|
||
if (-not([string]::IsNullOrEmpty($BasicAuthCreds))) { | ||
$BASICAUTH = [System.Convert]::ToBase64String([System.Text.Encoding]::ASCII.GetBytes($BasicAuthCreds)) | ||
$HEADERS.add("Authorization","Basic $BASICAUTH") | ||
} | ||
|
||
|
||
Write-Output "Performing action $Method on $Url." | ||
|
||
$Response = Invoke-WebRequest -Method Post -Headers $HEADERS -TimeoutSec $Timeout -Uri "$Url" -Form $Body -ContentType "application/x-www-form-urlencoded" | ||
|
||
} | ||
|
||
Write-Output "------- CONFIG ----------" | ||
Write-Output "AEM_SCHEMA: $AEM_SCHEMA" | ||
Write-Output "AEM_HOST: $AEM_HOST" | ||
Write-Output "AEM_PORT: $AEM_PORT" | ||
Write-Output "AEM_USER: $AEM_USER" | ||
Write-Output "CONTENT_SOURCE: $CONTENT_SOURCE" | ||
Write-Output "ROOT_PATH: $ROOT_PATH" | ||
Write-Output "FILTER_FILE: $FILTER_FILE" | ||
Write-Output "Silent: $Silent" | ||
Write-Output "VLT_FLAGS: $VLT_FLAGS" | ||
Write-Output "VLT_CMD: $VLT_CMD" | ||
Write-Output "ROOT_PATHS:" | ||
$ROOT_PATHS | ForEach-Object { | ||
Write-Output " - $_" | ||
} | ||
Write-Output "SERVICES_TO_DISABLE:" | ||
$SERVICES_TO_DISABLE | ForEach-Object { | ||
Write-Output " - $_" | ||
} | ||
|
||
if (-not($Silent)) | ||
{ | ||
$START = Read-Host -Prompt 'Do you want to start import with these settings? (y/n)' | ||
|
||
if ($START -ne "y") | ||
{ | ||
Write-Output "Quiting..." | ||
Exit | ||
} | ||
} | ||
|
||
Write-Output "------- Revert META-INF ----------" | ||
git checkout HEAD src/main/content/META-INF/ | ||
git clean -fx src/main/content/META-INF | ||
Write-Output "------- Revert META-INF ----------" | ||
|
||
if ($ROOT_PATHS) | ||
{ | ||
Write-Output "------- START Update filter ----------" | ||
$ROOT_PATHS_LAST = $ROOT_PATHS | Select-Object -Last 1 | ||
$ROOT_PATHS | ForEach-Object { | ||
$LOG_FILENAME = "$_".Replace("/","-") | ||
|
||
Write-Output "Remove exiting Filer..." | ||
Copy-Item ".\src\main\content\META-INF\vault\filter-blank.xml" -Destination "$FILTER_FILE" | ||
|
||
Write-Output "Create filter for: $_" | ||
$FILTER_XML = [xml](Get-Content $FILTER_FILE) | ||
$FILTER_XML_CONTENT = $FILTER_XML.SelectNodes("//workspaceFilter") | ||
$FILTER_XML_DELETE = $FILTER_XML_CONTENT.SelectNodes('//filter') | ||
$FILTER_XML_DELETE | ForEach-Object{ | ||
$DELETE_STATUS = $FILTER_XML_CONTENT.RemoveChild($_) | ||
} | ||
$FILTER_XML_CONTENT_NEW = $FILTER_XML.CreateNode("element","filter","") | ||
$FILTER_XML_CONTENT_NEW.SetAttribute("root",$_) | ||
$FILTER_XML_CONTENT_NEW_ADD = $FILTER_XML_CONTENT.AppendChild($FILTER_XML_CONTENT_NEW) | ||
Write-Output "Saving..." | ||
$FILTER_XML.OuterXml | IndentXML -Indent 4 | Out-File $FILTER_FILE -encoding "UTF8" | ||
Write-Output "Done..." | ||
} | ||
|
||
Write-Output "------- END Update filter ----------" | ||
} | ||
|
||
if ($SERVICES_TO_DISABLE) | ||
{ | ||
Write-Output "------- Disable Services ----------" | ||
$SERVICES_TO_DISABLE | ForEach-Object { | ||
Write-Output "Stopping service: $_" | ||
doSlingPost -Method Post -Referer $ADDRESS -UserAgent "curl" -Body $BODY_SERVICE_TO_DISABLE -Url "${ADDRESS}$_" -BasicAuthCreds ${AEM_USER}:${AEM_PASSWORD} -Timeout $TIMEOUT | ||
} | ||
} | ||
|
||
Write-Output "------- START Importing content ----------" | ||
Write-Output "${VLT_CMD} ${VLT_FLAGS} --credentials ${AEM_USER}:****** import -v ${ADDRESS}${AEM_WEBDAV_PATH} ${CONTENT_SOURCE} ${ROOT_PATH}" | ||
|
||
Invoke-Expression -Command "${VLT_CMD} ${VLT_FLAGS} --credentials ${AEM_USER}:${AEM_PASSWORD} import -v ${ADDRESS}${AEM_WEBDAV_PATH} ${CONTENT_SOURCE} ${ROOT_PATH} " | Tee-Object -FilePath "${LOG_PATH}\filevailt-import.log" | ||
|
||
Write-Output "------- END Importing content ----------" | ||
|
||
|
||
if ($SERVICES_TO_DISABLE) | ||
{ | ||
Write-Output "------- Enable Services ----------" | ||
$SERVICES_TO_DISABLE | ForEach-Object { | ||
Write-Output "Stopping service: $_" | ||
doSlingPost -Method Post -Referer $ADDRESS -UserAgent "curl" -Body $BODY_SERVICE_TO_DISABLE_ENABLE -Url "${ADDRESS}$_" -BasicAuthCreds ${AEM_USER}:${AEM_PASSWORD} -Timeout $TIMEOUT | ||
} | ||
} | ||
|
||
Write-Output "------- Revert META-INF ----------" | ||
git checkout HEAD src/main/content/META-INF/ | ||
git clean -fx src/main/content/META-INF | ||
Write-Output "------- Revert META-INF ----------" |
3 changes: 3 additions & 0 deletions
3
...main/content/jcr_root/apps/aemdesign/components/cloudservices/genericsnippet/.content.xml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
<?xml version="1.0" encoding="UTF-8"?> | ||
<jcr:root xmlns:granite="http://www.adobe.com/jcr/granite/1.0" xmlns:cq="http://www.day.com/jcr/cq/1.0" xmlns:jcr="http://www.jcp.org/jcr/1.0" | ||
jcr:primaryType="cq:Component"/> |
Oops, something went wrong.