Page 1 sur 1

Exécuter exe en tant qu'admin dans une session utilisateur

Posté : 03 févr. 2017 - 17:56
par atriou
Bonjour,

Je cherche à déployer la version host de teamviewer version 12 avec l'affectation automatique à mon compte en ligne.

Pour cela je déploie le msi et le fichier de config TeamViewer_Settings.reg au travers de l'outil wapt. Lors du déploiement avec le compte system du service WAPT, le PC n'est pas connecté à Internet (proxy transparent basé sur compte ad windows). L'internet est actif sur le PC que lorsqu'une session utilisateur est ouverte. Dés lors le client host de teamviewer établit une connexion avec les serveurs de teamviewer sur Internet, et se retrouve "personnalisé" : activation de la licence, le fichier "AssignmentData.json" est généré dans le répertoire de teamviewer "C:\Program Files (x86)\TeamViewer".

L'éditeur Teamviewer décrit une procédure pour affecter l'identifiant teamviewer du PC à un compte en ligne teamviewer. Il faut exécuter leur utilitaire "TeamViewer_Assignment.exe" avec certains arguments.

Malheureusement le fichier "AssignmentData.json" est généré avec des attributs très restreints, seulement un droit de lecture au groupe Administrateurs local du PC.

Si j'exécute l'utilitaire "TeamViewer_Assignment.exe" dans le "def install()" du paquet wapt, je n'ai pas de connexion internet -> pas de fichier "AssignmentData.json" généré, etc.

Si j'exécute l'utilitaire "TeamViewer_Assignment.exe" dans le "session_setup", il faut qu'un compte administrateur ouvre la session pour que tout fonctionne. C'est problématique car tous mes usagers sont "utilisateur".

Je n'ai pas de notion de programmation python, je parcours les docs de la communauté et m'inspire des modèles des paquets existants. J'imaginai une astuce afin d'exécuter l'utilitaire "TeamViewer_Assignment.exe" en tant qu'administrateur dans une session utilisateur.

Est-ce possible ? Si oui comment ou avez-vous une autre méthode à me proposer ?

En vous remerciant.

Ci-dessous les sources de mon paquet (l'utilitaire "TeamViewer_Assignment.exe" est dans le répertoire temp) :

Code : Tout sélectionner

from setuphelpers import *

uninstallkey = []

destdir = makepath('c:\\wapt\\temp')

def install():
    print('installing atr-teamviewer-host12')
    copytree2('temp',destdir,onreplace=default_overwrite_older)
    install_msi_if_needed('TeamViewer_Host-xxxxxxxxxx.msi',killbefore=['teamviewer.exe'])


def session_setup():
    install_exe_if_needed("%s\TeamViewer_Assignment.exe" % destdir,silentflags='-apitoken 1234567-xxxxxxxxxxxxxxxxxxxx -datafile "${ProgramFiles}\TeamViewer\AssignmentData.json"',accept_returncodes=[0,1],timeout=30)


def uninstall():
    print "Remove directory content %s" % destdir
    remove_tree(destdir)

Re: Exécuter exe en tant qu'admin dans une session utilisateur

Posté : 06 févr. 2017 - 09:02
par Aedenth
Bonjour,

vous pouvez surement le faire en créant via wapt une tache planifiée qui s'execute une fois au démarrage en tant qu'admin, grâce à schtasks.

Code : Tout sélectionner

run(schtasks /create /tn <TaskName>/TR <TaskRun>/SC fois /St <HH:MM>[/sd <StartDate>] [/it] [/ru {[<Domain> \] <User>[/rp <Password>] | Système}] [/ s <Computer>[/u [<Domain> \] <User>[/p <Password>]]]
Doc schtasks : https://technet.microsoft.com/fr-fr/lib ... #BKMK_once

Re: Exécuter exe en tant qu'admin dans une session utilisateur

Posté : 06 févr. 2017 - 23:53
par sfonteneau
Il serait peut être plus simple pour vous d'autoriser vos poste a se connecter a teamviewer ?

Quelle type d'authentification utilisez-vous ? Ntlm ? Kerberos ? autre ?

Re: Exécuter exe en tant qu'admin dans une session utilisateur

Posté : 09 févr. 2017 - 12:05
par atriou
Pas encore eu le temps de tester la tache planifiée.

Nos utilisateurs s'authentifient sur leur poste au travers d'un AD Microsoft (niveau fonctionnel 2008 il me semble), le protocole d'authentification est kerberos.

Je vais poster un message sur le support de teamviewer pour savoir pourquoi le fichier "AssignmentData.json" est généré avec des attributs très restreints (seulement un droit de lecture au groupe Administrateurs local du PC).