IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Scripts/Batch Discussion :

TOP 10 des plus vielles connection AD [PowerShell]


Sujet :

Scripts/Batch

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2017
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2017
    Messages : 2
    Par défaut TOP 10 des plus vielles connection AD
    J'essaye de faire un script pour avoir le top 10 des plus vielles connexion AD mais je bloque pour les dates, voici se que j'ai déjà fait.

    Code powershell : Sélectionner tout - Visualiser dans une fenêtre à part
    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
    64
    65
     
    Import-Module ActiveDirectory
     
    function Get-ADUsersLastLogon()
    # Fonction permettant d'avoir la dernière connection d'un utilisateur AD
    {
    # Déclaration des variables
     
      $dcs = Get-ADDomainController #-Filter {Name -like "*"}
      # Cherche sur tout les domaines 
      $users = Get-ADUser -Filter *
      # Cherche sur tout les utilisateurs
      $time = 0
      # Valeur du temps égale 0
      #$exportFilePath = "d:\lastLogon.csv"
      # Exportation des valeur dans le fichier lastlogon à la racine de D
      $columns = "name,username,datetime"
      # Créer des colonnes 
      $buf = @()
     
     
      #Out-File -filepath $exportFilePath -force -InputObject $columns
      # Création du fichier avec les colonnes
     
      foreach($user in $users)
      # Pour chaque utilisateur dans utilisateurs
      {
        foreach($dc in $dcs)
        # Pour chaque contrôleur de domaine dans controleur de domaine
        { 
          $hostname = $dc.HostName
          # ?
          $currentUser = Get-ADUser $user.SamAccountName | Get-ADObject -Server $hostname -Properties lastLogon
          # L'utilisateur actuel égale cette commande
     
          if($currentUser.LastLogon -gt $time) 
          # Si la dernière connexion de l'utilisateur actuel est plus grand que le temps 0
          {
            $time = $currentUser.LastLogon
            # LastLogon est un paramètre
          }
        }
     
        $dt = [DateTime]::FromFileTime($time)
        $item = {} | Select Name,Username,LastLogon
        $item.Name = $user.Name
        $item.Username = $user.SamAccountName
        $item.LastLogon = $dt
     
        $buf += $item
     
        #$row = ","++","+
     
        #Out-File -filepath $exportFilePath -append -noclobber -InputObject $row
        #$row | Sort -Descending datetime | Select-Object -First 10
     
     
     
        $time = 0
      }
     
      $buf
    }
     
     Get-ADUsersLastLogon | Select-Object -First 10

    C'est pour avoir les plus vielles et exclure les connections qui ont comme date 01/01/1601 01:00:00 ou je bloque.

    Merci d'avance

  2. #2
    Membre chevronné
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Février 2012
    Messages
    281
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Lot et Garonne (Aquitaine)

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux
    Secteur : Industrie

    Informations forums :
    Inscription : Février 2012
    Messages : 281
    Par défaut
    salut Atlante21

    comme c'est bientôt noël, je t'ai refais ton script pour qu'il fonctionne
    les corrections :
    - la liste de DC
    - l'utilisation de lastlogontimestamp plus a jours a la place de lastlogon
    - suppression du Get-ADObject inutile
    - modification du if pour la recupe de la plus ancienne date des DC

    joyeux noël
    Code powershell : Sélectionner tout - Visualiser dans une fenêtre à part
    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
    64
    65
     
    Import-Module ActiveDirectory
     
    function Get-ADUsersLastLogon() {
    # Fonction permettant d'avoir la dernière connection d'un utilisateur AD
     
        # Déclaration des variables
     
        $dcs = (Get-ADDomain).ReplicaDirectoryServers
        # Cherche sur tout les domaines 
        $users = Get-ADUser -Filter *
        # Cherche sur tout les utilisateurs
        #$exportFilePath = "d:\lastLogon.csv"
        # Exportation des valeur dans le fichier lastlogon à la racine de D
        $columns = "name,username,datetime"
        # Créer des colonnes 
        $buf = @()
     
     
        #Out-File -filepath $exportFilePath -force -InputObject $columns
        # Création du fichier avec les colonnes
     
        foreach($user in $users) {
            # Pour chaque utilisateur dans utilisateurs
            $time = $false
            foreach($dc in $dcs) {
            # Pour chaque contrôleur de domaine dans controleur de domaine
                # ?
                $currentUser = Get-ADUser $user.SamAccountName -Server $dc -Properties lastLogon, lastlogontimestamp
                # L'utilisateur actuel égale cette commande
     
                if ($currentUser.lastlogontimestamp -ne $null -and $currentUser.lastlogontimestamp -ne 0) {
                # Si la dernière connexion de l'utilisateur actuel est plus grand que le temps 0
                    $time = $currentUser.lastlogontimestamp
                    # LastLogon est un paramètre
                    }
                }
     
            $item = {} | Select Name,Username,lastlogon
            $item.Name = $user.Name
            $item.Username = $user.SamAccountName
            if ($time) {
                $dt = [DateTime]::FromFileTime($time)
                $item.LastLogon = $dt
                }
            else {
                $item.LastLogon = "Jamais connecter"
                }
     
            $buf += $item
            #$row = ","++","+
     
            #Out-File -filepath $exportFilePath -append -noclobber -InputObject $row
            #$row | Sort -Descending datetime | Select-Object -First 10
     
            }
     
        $buf
        }
     
    # les dix plus anciennes connexion sauf ceux qui ne se sont jamais connecter ou d'avant le dernier changement de serveur DC
    Get-ADUsersLastLogon | where {$_.lastlogon -ne "Jamais connecter"} | sort LastLogon | Select-Object -First 10 
     
    # les utilisateurs qui ne se sont jamais connecter ou datant d'avant le dernier changement de serveur DC
    Get-ADUsersLastLogon | where {$_.lastlogon -eq "Jamais connecter"} | sort Name

    amélioration possible :
    - suppression de la double interrogation DC pour accéléré le script si on demande que des connexion de plus de 14 jours
    - sélection des jamais connecter dans l'appel de la fonction

  3. #3
    Nouveau candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2017
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2017
    Messages : 2
    Par défaut
    Merci joyeux noël

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Parallel I/O et le Top 10 des plus grands défis de stockage
    Par Danboe dans le forum Communiqués
    Réponses: 0
    Dernier message: 01/03/2016, 19h05
  2. Réponses: 26
    Dernier message: 24/02/2010, 17h00
  3. top 10 des requêtes les plus longues
    Par cseguino dans le forum Administration
    Réponses: 1
    Dernier message: 10/02/2010, 09h46
  4. Obtenir le top 10 des membres postant le plus
    Par error404 dans le forum Langage SQL
    Réponses: 3
    Dernier message: 04/03/2008, 10h43
  5. Réponses: 9
    Dernier message: 30/01/2007, 17h03

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo