-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathSearch-Query.ps1
More file actions
63 lines (47 loc) · 1.57 KB
/
Search-Query.ps1
File metadata and controls
63 lines (47 loc) · 1.57 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
function Search-Query {
[CmdletBinding()]
param (
[Parameter(ValueFromPipelineByPropertyName = $True)]
[String]
$ServerName,
[Parameter(ValueFromPipelineByPropertyName = $True)]
[String]
$Statement
)
begin {
}
process {
$server = $aemEnv | Where-Object -Property name -Value $ServerName -eq
if ($server -eq $null) {
Write-Error -Message "ServerName $ServerName is not found."
return;
}
$headers = @{
Authorization = Get-BasicAuthorizationValue -Username $server.username -Password $server.password;
"User-Agent" = "curling"
}
$form = @{
"_charset_" = "utf-8"
"type" = "JCR-SQL2"
"stmt" = $Statement
"showResults" = "true"
}
try {
$url = $server.url
$res = Invoke-WebRequest -Uri "$($url)/crx/de/query.jsp" -Method Get -Headers $headers -Body $form
$($res.Content | ConvertFrom-Json).results | % {
$obj = New-Object -TypeName psobject
$obj | Add-Member -MemberType NoteProperty -Name ServerName -Value $ServerName
$obj | Add-Member -MemberType NoteProperty -Name Path -Value $($_.path)
Write-Output $obj
}
}
catch {
# throw $_.Exception
Write-Error -Message "Query failed."
return
}
}
end {
}
}