Skip to content

Latest commit

 

History

History
260 lines (218 loc) · 8.21 KB

README.md

File metadata and controls

260 lines (218 loc) · 8.21 KB

shell-commands

PS commands I use often

Remote PS

Enter-PSSession -ComputerName nameishere

Remote cmd

psexec \\hostname cmd

Delete files with cmd

rmdir /s /q C:\Windows.old
takeown /F "C:\Windows.old" /A /R /D Y
RD /S /Q "C:\Windows.old"

.net 3.5 setup (Source:Windows iso)

DISM /Online /Enable-Feature /FeatureName:NetFx3 /All /LimitAccess /Source:X:\sources\sxs

Check .net version

Get-ItemProperty 'HKLM:\SOFTWARE\Microsoft\NET Framework Setup\NDP\v4\Full' | Select-Object Version

Get hyper-v host

Get-ItemProperty 'HKLM:\SOFTWARE\Microsoft\Virtual Machine\Guest\Parameters\' | Select-Object HostName

Check hash

Get-FileHash .\dosya -Algorithm SHA256

Get permissions

net localgroup Administrators
net localgroup "Remote Desktop Users"

Get users with ID (local)

gwmi win32_userprofile | select localpath, sid

Get user from group

Get-ADGroupMember -Identity "groupname" -Recursive | Get-ADUser -Properties Name,  EmployeeID, userPrincipalName, distinguishedName

Get user from group with export

Get-ADGroupMember -Identity "groupname" -Recursive | Get-ADUser -Properties Name, EmployeeID, userPrincipalName, distinguishedName | Export-csv -path C:\caglar-export\test.csv -notypeinformation -Encoding UTF8 

List dc

Get-ADDomainController -Filter * | Select hostname, site

Install Telnet Client

Install-WindowsFeature -name Telnet-Client

Get locked user from domain

Search-ADAccount -LockedOut -ResultPageSize 2000 -resultSetSize $null | Select-Object Name, SamAccountName, DistinguishedName | Export-CSV C:\LockedUserList.CSV -NoTypeInform

Get Group Member from AD

Get-ADGroupMember -Identity 'Groupname' -Recursive | Select Name

Get Active Users on AD

Get-ADUser -server dc.hostname.com -Filter {enabled -eq "true" -and objectclass -eq "user"} -properties * | Select-Object Name,SamAccountName,lastlogondate | 
Export-csv C:\DomainUsers.csv -NoTypeInformation -Encoding UTF8

Get domain users

Get-ADUser -server adserver.domain.com -Filter {enabled -eq "true" -and objectclass -eq "user"} -properties lastlogondate, enabled | Select-Object Name,SamAccountName,lastlogondate, enabled | 
Export-csv C:\domain_users.csv -NoTypeInformation -Encoding UTF8

$attributes = 'EmployeeID','Name','SamAccountName','Description','PasswordLastSet','emailaddress','PasswordNeverExpires','whencreated','whenchanged','lastlogondate',@{n='lastlogontimeStamp';e={[DateTime]::FromFileTime($_.lastlogontimestamp)}},'enabled'
 
Get-ADUser -server adserver.domain.com -Filter {enabled -eq "true" -and objectclass -eq "user"} -properties * | select $attributes | 
Export-csv C:\domain_users.csv -NoTypeInformation -Encoding UTF8 -Delimiter ";" 

Get mail address from AD users

Get-ADObject -Filter {(objectclass -eq 'contact') -and ((targetaddress -like "*domain.com*") -or (targetaddress -like "*filteradresshere*"))} -Properties *  | 
select cn,targetaddress,memberof,objectclass | out-file c:\therearefilter_contacts.csv 

Get name and mail address from AD groups

Get-ADGroup -properties * -Filter  {(name -like "*sube grubu*")} |select name,mail | Export-Csv "C:\SubeGrubu.csv" -Encoding UTF8 -NoTypeInformation

Get last modified date of computer object from AD

Get-ADcomputer -Filter 'Name -like "*computernamewashere"' -properties * | sort lastlogondate | FT name, whenChanged

Get OU of hostname from AD

Get-ADcomputer -Filter 'Name -like "*computernamewashere"' -properties * | sort lastlogondate | FT name, CanonicalName

Get OU of hostname list from AD

Get-Content C:\hostnames.txt | foreach {Get-ADComputer -Filter {Name -Like $_} -properties *} | sort lastlogondate | FT name, CanonicalName

Change dns of servers

$servers = Get-Content "E:\liste.txt"
#$servers = "hostname"
foreach($server in $servers){
    Write-Host "Connect to $server..."
    $nics = Get-WmiObject Win32_NetworkAdapterConfiguration -ComputerName $server   | Where{$_.IPEnabled -eq "TRUE"}
    $newDNS = "1.1.1.1","1.0.0.1"
foreach($nic in $nics){
    Write-Host "`tExisting DNS Servers " $nic.DNSServerSearchOrder
    $x = $nic.SetDNSServerSearchOrder($newDNS)
    if($x.ReturnValue -eq 0){
    Write-Host "`tSuccessfully Changed DNS Servers on " $server -ForegroundColor Green
     }
     else{
     Write-Host "`tFailed to Change DNS Servers on " $server -ForegroundColor Red
         }
   }
}

Check disk size

Get-Volume -DriveLetter C

Set TR Timezone

Set-TimeZone -Id "Turkey Standard Time"

Applications sent from SCCM

get-wmiobject -query "SELECT * FROM CCM_Application" -namespace "ROOT\ccm\ClientSDK" | Select-Object FullName, InstallState

Get installed softwares

get-wmiobject -Class Win32_Product | Select-Object Name, Version

Get services status

Get-Service -Name "servicesname*"
Get-Service | Where-Object {$_.Status -eq "Running"}
Get-Service "s*" | Sort-Object status

To get information about the last time the servers communicated with the domain

$ComputerList = get-content "E:\Liste.txt"
#$ComputerList = "hostname"
  foreach ($Computer in $ComputerList)
{
  TRY
    {
  $LastLogonQuery = Get-ADComputer $Computer -Properties lastlogontimestamp | 
    #Select-Object @{n="Computer";e={$_.Name}}, @{Name="Lastlogon"; Expression={[DateTime]::FromFileTime($_.lastLogonTimestamp)}}
    Select-Object @{n='lastLogonTimestamp';e={[DateTime]::FromFileTime($_.lastLogonTimestamp).ToString("dd/MM/yyyy")}}
     $Computer   +  "*ADLastLogonTime*"  + $LastLogonQuery.lastLogonTimestamp
 }
Catch    {
   $Computer   +  "*ADLastLogonTime*"  + "NOObject"
	}
}

Install sscm agent

CCMSetup.exe /mp:sub.domain.com SMSSITECODE=domainsitecode FSP=sscmserver.domain.com

Collectively Move all on AD OU

Get-Content C:\import.txt| foreach {Get-ADComputer -Filter {Name -Like $_} |Move-ADObject -TargetPath "OU=Tier0,OU=App Servers,OU=OU,OU=OU,DC=DC,DC=local"}

Get samaccountname from name and surname

Get-ADUser -Filter 'Name -like "*namesurname"' | Format-Table Name,SamAccountName -A

Get userPrincipalNames from samaccountname

Get-ADUser accountname -Properties * | select userPrincipalName

Exchange Mail Inbox Receipt Check

Get-TransportService | Get-MessageTrackingLog -start "9/22/2022 9:00:00 AM" -end "9/22/2022 3:00:00 PM" -Sender "sender@mail.com" -Recipients "recipients@mail.com"

Set Mail AutoReply

Set-MailboxAutoReplyConfiguration ADUSERNAME -AutoReplyState enabled -ExternalAudience all -InternalMessage "Message was here"

Get user mail export

(all)
New-MailboxExportRequest -Mailbox username -AcceptLargeDataLoss -BadItemLimit 150 -FilePath \\filepath\file.pst
(The date is intermittent / The dates should be set according to the zone setting of the machine to be exported)
New-MailboxExportRequest -ContentFilter {(Received -lt '07/26/2021') -and (Received -gt '07/05/2021')} -Mailbox "ADusername" -Name nameishere -FilePath \\filepath\inboxname.pst
(status export)
Get-MailboxExportRequest
(remove of completed)
Get-MailboxExportRequest -Status completed | Remove-MailboxExportRequest

Get mail groups from AD (run with exc management shell)

Get-DistributionGroup -Filter * -ResultSize unlimited |select name, PrimarySmtpAddress  | Export-Csv c:\MailGroup.csv -NoTypeInformation -Encoding UTF8

Get 0kb files from path

New-PSDrive -Name P -PSProvider FileSystem -Root "\\server\share"
Get-ChildItem -Path P:\SourcePATH -Recurse -Force | Where-Object { $_.PSIsContainer -eq $false -and $_.Length -eq 0 } | Select -ExpandProperty FullName | Add-Content -Path c:\export.txt