Projet

Général

Profil

FsUserCreat.pl

Lit les arguments et génère des fichiers de config d'utilisateur pour freeswitch

fsUserCreate.pl <extension> <identifiant> <password>

generera les fichiers de config pour un seul utilisateur. Les argument suivants seront ignorés.

fsUsercreate.pl -f <fichiers1> <fichiers2>

Avec l'option -f les arguments seront des fichiers où chaque ligne sera lue comme une suite d'arguments dans l'ordre : . Plusieurs fichiers peuvent être lus à la suite.

Exemples

fsUserCreate.pl 2010 toto secretpass123

generera un utilisateur nommé toto portant l'extension (numero d'appel) 2010 et qui aura pour mot de passe secretpass123 .

fsUsercreate.pl -f listeUtilisateurs

lira le fichier listeUtilisateurs dans lequel chacune des lignes decrira un utilisateur sur le modèle précédent.

Code source

#! /usr/bin/perl -s

use XML::Writer;
use IO::File;

############
#       FUNCTIONS
#
#       - readUserFile
#               Read list of users from a file and push it in the array
#       - generateUser
#               Generate XML directory files for freeswitch from the array
#
############

sub readUserFile {      # Read userlist from a file
        open(FICHIER,"<$fileNumber") or die("open:  $!") ;

        while ($line =<FICHIER>)        {
                if ( $line =~ /^$/ )    {
        #               PRINT "ligne vide.\n" ;
        #               next ;
                } else  {
                @words = split ( /\W+/ , $line  ) ;
                push @userList, { uid => @words[0], name => @words[1], pass => @words[2] };
                }
        }

        close FICHIER ;
}

sub generateUser  {
        my ( $userUid, $userName, $userPass ) = @_ ;            # Get the data from sources

        my $outputdir = "/usr/local/freeswitch/conf/directory/default" ;

#       my $outputFile = $userUid ;                                                     # The output file will be named with user's uid

        my $output = new IO::File(">$outputDir/$userId.xml");           # Et voilà !

        my $writer = new XML::Writer( 
        OUTPUT      => $output,
        DATA_INDENT => 8,             # indentation, huit espaces
        DATA_MODE   => 1,             # changement ligne.
        ENCODING    => 'utf-8',
        );

        # Ok! Now let's generate some Good'Ol' XML !!

        $writer->comment("This file was auto generated and will may be again. Do not edit it manually, modifications could be lost");

        $writer->startTag( "include" ) ;
                $writer->startTag( "user", "id" => $userUid );
                        $writer->startTag( "params" ) ;
#                               $writer->emptyTag( "param", "name" => "password", "value" => "\$\${default_password}" ) ;
                                $writer->emptyTag( "param", "name" => "password", "value" => $userPass ) ;
                                $writer->emptyTag( "param", "name" => "vm-password", "value" => $userUid ) ;
                        $writer->endTag( "params" ) ;

                        $writer->startTag( "variables" ) ;
                                $writer->emptyTag( "variable" , "name" => "toll_allow", "value" => "domestic,international,local" ) ;
                                $writer->emptyTag( "variable" , "name" => "accountcode", "value" => $userUid ) ;
                                $writer->emptyTag( "variable" , "name" => "user_context", "value" => "default" ) ;
                                $writer->emptyTag( "variable" , "name" => "effective_caller_id_name", "value" => $userName ) ;
                                $writer->emptyTag( "variable" , "name" => "effective_caller_id_number", "value" => $userUid ) ;
                                $writer->emptyTag( "variable" , "name" => "outbound_caller_name", "value" => "\$\${outbound_caller_name}" ) ;
                                $writer->emptyTag( "variable" , "name" => "outbound_caller_number", "value" => "\$\${outbound_caller_id}" ) ;
                                $writer->emptyTag( "variable" , "name" => "callgroup", "value" => "techsupport" ) ;
                        $writer->endTag( "variables" ) ;


                $writer->endTag("user");
        $writer->endTag("include");


#       my $outputFile = $userName ;                                                    # The output file will be named with user's uid

        my $output = new IO::File(">$outputDir/$userName.xml");         # Et voilà !
#       my $output = new IO::File(">/usr/local/freeswitch/conf/directory/default/$outputFile.xml");             # Et voilà !

        my $writer = new XML::Writer( 
        OUTPUT      => $output,
        DATA_INDENT => 8,             # indentation, huit espaces
        DATA_MODE   => 1,             # changement ligne.
        ENCODING    => 'utf-8',
        );

        # Ok! Now let's generate some Good'Ol' XML !!

        $writer->comment("This file was auto generated and will may be again. Do not edit it manually, modifications could be lost");

        $writer->startTag( "include" ) ;
                $writer->startTag( "user", "id" => $userName , "cidr" => "192.0.2.0/24" );

                        $writer->startTag( "gateways" ) ;
                        $writer->endTag( "gateways" ) ;

                        $writer->startTag( "params" ) ;
#                               $writer->emptyTag( "param", "name" => "password", "value" => "\$\${default_password}" ) ;
                                $writer->emptyTag( "param", "name" => "password", "value" => $userPass ) ;
                                $writer->emptyTag( "param", "name" => "vm-password", "value" => $userUid ) ;
                        $writer->endTag( "params" ) ;

                        $writer->startTag( "variables" ) ;
                                $writer->emptyTag( "variable" , "name" => "user_context", "value" => "default" ) ;
                                $writer->emptyTag( "variable" , "name" => "effective_caller_id_name", "value" => $userName ) ;
                                $writer->emptyTag( "variable" , "name" => "effective_caller_id_number", "value" => $userUid ) ;
                                $writer->emptyTag( "variable" , "name" => "process_cdr", "value" => "true" ) ;
                                $writer->emptyTag( "variable" , "name" => "sip_secure_media", "value" => "true" ) ;
                        $writer->endTag( "variables" ) ;

                        $writer->startTag( "vcard" ) ;
                        $writer->endTag( "vcard" ) ;

                $writer->endTag("user");
        $writer->endTag("include");
}

#############
#  ACTION
##################
if ( $f ==1 )   {                       # if switch f is on 
        for $fileNumber ( @ARGV ) {     # read arguments as list of source files
                readUserFile ;          # and treat them with readUserFile Function
        }
}
else    {                               # else simply push arguments in the array
        push @userList, { uid => @ARGV[0], name => @ARGV[1], pass => @ARGV[2] };
}

for $i ( @userList ) {                  # for each user in the array
        generateUser( $i->{uid}, $i->{name}, $i->{pass} ) ;     # generate appropriate XML files with generateUser
        print "Files for user $i->{name} with extension $i->{uid} successfully generated.\n" ;
}

H2. TODO

  • Trouver une extension libre si celle ci n'est pas mentionnée.

  • Option pour parser LDAP

  • Liste les utilisateurs si aucun argument

  • Option R pour supprimmer un ou des utilisateurs

  • Demander confirmation avant ecrasement si un utilisateur existe deja. Option F pour passer outre et forcer.