Category Archives: IT

Adding photos in AD

Within Active Directory of Microsoft there is a thumbnailPhoto entry where you can place a small photo. These pictures should preferably be 96 by 96 pixels and not larger than 10kb. You might create those photos from an already existing source and batch process them with something like Irfanview so they become the right size. There are several tools available to import them into Active Directory and they will also resize the picture, but it is possible to do this with PowerShell as well. The features are explained in the source code itself. In short it will read the pictures from a single source where the name of the picture should be similar to the logon name of the user and it will check if pictures are not exceeding the above mentioned limits. If successful the source picture is deleted, if not it is kept and a report is sent which can trigger a person to see what is wrong with the picture.

#requires -version 2

<#
Program  : ADPhotoImport.ps1
Author   : Eugene Dullaard
Date     : 14-Jul-2014
           - Initial Script

This script will import pictures from a source into Active Directory's
thumbnailPhoto field from a fixed content source.

Requirements:

Photo : 96x96 pixels and smaller than 10Kb
        filename in the format of <username>.jpg

Features :

- Content source is leading, it will search AD accounts by the name of the
  picture. The name without the extension of the picture should be matching
  SAMAccountName in Active Directory and can include dots, for example user
  account ab.user its picture should be ab.user.jpg.
- Check properties of picture before importing so that they comply with above
  requirements, wrong pictures will be added to an output report which is
  send after the script finishes.
- Remove photo once processed, keeping content source clean and allow for
  updating of existing pictures.
- If pictures exist and the corresponding account cannot be found this will
  be added to the output report. In this case the picture will not be removed.
- Runs with both a Content source as well as a Searchbase for the accounts.
- Searchbase will be searched recursively. Picture folder will not as it
  should delete the pictures once they've been processed. You should keep
  any existing source or have a seperate one if pictures need to be kept.
- Screen output for operator to see output while looking at the progress.
- Reporting errors will allow automated use of this script and corrective
  measures taken afterwards.
#>

#Variables (Change these to suit your environment)

$Content = "\\Server\Share\Folder"        # Content Source (Drive/UNC Path)
$Accounts = "OU=Users,DC=domain,DC=tld"   # User Accounts OU
$MailSender = "photoimport@domain.tld"    # Report Sent from mail address
$ReportAddress = "name@domain.tld"        # Report Sent to mail address
$SMTPServer = "mailserver.domain.tld"     # Mail server for relaying message

#Preliminaries

  Import-Module ActiveDirectory
  Add-Type -AssemblyName System.Drawing

  #Generate List of Photos in Content Source
  $Photos = Get-ChildItem $Content -Filter *.jpg

  #Report Header
  $Report = "Error report on ADPhotoImport
==============================
  
Maximum picture dimensions are 96 x 96 pixels, maximum size is 10Kb.

"
  $ReportCheck = $Report.Length           # Used to check for added entries

#Start processing the List of Photos (Main Loop)

$Photos | % {

  # Reset variables
  $ErrorStatus = $false
  $Basename = $_.BaseName
  Write-Host "==========================================="
  Write-Host "Processing : $Basename"

  # Check picture dimensions and size, if in error add to log and show on screen
  $jpg = New-Object System.Drawing.Bitmap $_.FullName
  if ($jpg.height -gt 96) {
    $Report = $Report + "$_ `t Pixel height exceeded.`n"
    Write-Host "Error..... : Pixel height exceeded" -ForegroundColor Red
    $ErrorStatus = $true
  }
  if ($jpg.width -gt 96) {
    $Report = $Report + "$_ `t Pixel width exceeded.`n"
    Write-Host "Error..... : Pixel width exceeded" -ForegroundColor Red
    $ErrorStatus = $true
  }
  if ($_.length -gt 10240) {
    $Report = $Report + "$_ `t Size limitation exceeded.`n"
    Write-Host "Error..... : File size exceeded" -ForegroundColor Red
    $ErrorStatus = $true
  }
  $jpg.Dispose()

  # Check for AD Account, if not existing add to log.
  $user = Get-ADUser -SearchBase $Accounts -Filter {(SAMAccountName -eq $BaseName)}
  if ($user -eq $null) {
    $Report = $Report + "$_ `t No AD user has been found.`n"
    Write-Host "Error..... : No matching user account" -ForegroundColor Red
    $ErrorStatus = $true
  }

  # If no errors are found, insert/replace picture and delete from content source
  if ($ErrorStatus -eq $false) {
    [byte[]]$photo = Get-Content $_.FullName -Encoding Byte
    Set-ADUser $_.BaseName -Replace @{thumbnailPhoto=$photo}
    Remove-Item $_.FullName
  }
 
} # End Main Loop

# Check Report Change, if changed send report
If ($Report.Length -ne $ReportCheck) {
  Send-MailMessage -From $MailSender -To $ReportAddress -Subject "AD Photo Import Error Report" `
    -SmtpServer $SMTPServer -Body $Report
}

Update: In order to see which accounts do not have a thumbnail photo you can enter the following command in PowerShell:

Get-ADUser -Filter * -SearchBase "OU=Users,DC=domain,DC=tld" -properties thumbnailPhoto | ? {!$_.thumbnailPhoto} | select Name,SAMAccountName

If you want to see a list of who has a thumbnail photo remove the ‘!’ in the code line above.

Bye bye XP…

xpipfilter… and did we have fun with you. One of those was the TCP/IP filtering option. Just configure it to deny all traffic and what you got was a box that would get an IP address through DHCP and then denied all traffic towards the network. Do that to an unsuspecting helpdesk employee (who forgot to lock his or her desktop) and a world of joy unfolds…

Anyway after a longer than usual lifespan it is time to look somewhere else now.

Android Mail vs Exchange

Ran into an issue that the native mail client couldn’t be configured on an Android device (specifically a Galaxy S4 from Samsung with either a version 4.3 or 4.4 of Android on it). The server it should connect to is an older Exchange 2007 environment (UR11 at the time this was happening). When trying it always ended up with the remark that the supplied username and password where invalid. Looking into the configuration of the mail client there is a DeviceID mentioned starting with SEC and then a certain amount of hexadecimal numbers, while in Active Directory I found a DeviceID that started with androidc. Through the aid of powershell I added the SEC DeviceID as found in the mail profile of the phone, waited a few moments and then applied the settings again and this time it picked it up and is working. Below is a small script to add a DeviceID into Exchange if you have the same issue, just supply the Exchange Alias together with the DeviceID from the phone and it might work for you too. If it is more permanent I’ll update it with a nicer version that includes error handling and comments. Needless to say there needs to be some time spend on why this is happening.

$Alias = Read-Host "Exchange Alias ......... : "
$DevID = Read-Host "New ActiveSync Device ID : "
$DData = (Get-CASMailbox -Identity $alias).ActiveSyncAllowedDeviceIDs
$DData = $DData+$DevID
Set-CASMailbox -Identity $Alias -ActiveSyncAllowedDeviceIDs $DData
Write-Host "Written ActiveSyncDeviceID $DevID to alias $alias."

Interprocess Communications Depot?????

….. What’s that? Well the full error I was getting when trying to install a Cisco AnyConnect VPN client (2.5 or 3.0) is “The VPN client agent was unable to create the interprocess communications depot.”. The only thing I could do is just cancel the installation and then click away the error message. Still do not know what the above actually is but didn’t look for it either. When you have this error during an installation of the above mentioned software check your networkcard configuration to see if Internet Connection Sharing is enabled. If it is enabled please disable as it is preventing the VPN client from installing correctly. From the same person that came with this problem was also the remark that the installed version of the VPN client gave an error that it had problems with a network gateway, but didn’t have the exact error. The idea is clear though, do not enable ICS.

Issues mounting a memory stick in VM-Ware Player?

…… Did you turn on Virtualization Support in the BIOS? Had an issue with a laptop that ran a XP system virtually on a physical Windows 7 laptop. All was well however if you wanted to mount a USB stick to the VM it would end up with a driver error. The exact message is “The connection for the <Name of USB Device> was unsuccessful: Driver Error”. Googled it but couldn’t really find what I was looking for, lots of errors regarding device in use and others. Decided to check if Virtualization Support was turned on within the BIOS and found it disabled, enabled the support and immediately the mounting of a USB stick into the VM is now working fine. This most likely will go for USB based harddrives or other devices that will mount as a drive as well and might also apply to other operating systems that you’ve virtualized. Next is testing this with an ODB2 dongle with software that only is supported on Windows XP (as that was the driver for having a VM).

LDAP import on Blue-Mind 2.0.8

LDAP import into Blue-Mind 2.0.8 on Ubuntu 12.04LTS and maybe other Debian based installs as well.

Did an out of the box install of Blue-Mind 2.0.8 on a server to start investigating if Blue-Mind could replace my current Exchange Server install as it had the basics which are calendaring and activesync support for mobile devices, but found out that it couldn’t do the ldap-import according the instructions found here.

Blue Mind

It seems that the package website can be browsed as a directory so I went looking for the plugin name as that was mentioned on their community pages.

So, if you want to do LDAP imports on your Ubuntu 12.04LTS server within Blue-Mind you can do so with the following two commands:

wget “http://pkg.blue-mind.net/2.0.8/precise/main/bm-plugin-core-ldap-import_2.0.9987_amd64.deb
dpkg -i bm-plugin-core-ldap-import_2.0.9987_amd64.deb

You will need to use sudo of course and then restart Blue-Mind, after which you now have the “Directories” tab added as shown in the Blue-Mind knowledge base article mentioned above. However how to add it was missing in the knowledge base, or at least I never found it. Also it might be possible that it does install if you run OpenLDAP on the same server which was not so in my case. Hope this might help you out if you are struggling with the same issue.

ownCloud, resolve your Dropbox issue

owncloudSomehow I doubt that, but it will be the next experiment. Clients for Linux, MacOSX and Windows but also Android and iOS. The mobile ones are paid, currently going for € 0.79. For an experiment this is still affordable :-).

The features seem impressive, so lets give it a go. A dropbox clone that comes at 79 cents for the Android bit with storage limits that I can set myself is always welcome….. Bye bye dropbox or better yet, include it in ownCloud which seem to be a possibility.

reCaptcha

A nice way of translating books as you can see on their website and in the meantime deliver some kind of protection and as a benefit you aren’t completely wasting your seconds when typing them in to verify you are human.

My mail address is easily guessed but I will include the reCaptcha links for both Sunny’s and my own mail address for people with a shortage in braincapacity.

You can try on our Contact Us page.