Remote Desktop from linux to windows

To be able to rdp from a linux box to a windows box you must have find a program that uses windows' proprietary rdp protocol. http://www.rdesktop.org/ seems to be the best program this. The rdesktop software requires libX11-devel to be installed

To install rdesktop:
  1. yum install libX11-devel
  2. cd  /home/[username]/Download
  3. wget http://prdownloads.sourceforge.net/rdesktop/rdesktop-1.6.0.tar.gz?download
  4. tar -xvzf rdesktop-1.6.0.tar.gz
  5. cd redesktop-1.6.0
  6. ./configure
  7. make
  8. makeinsall
To run rdesktop:
  1. run rdesktop from the command line

VPN From Fedora to Edgemarc

To setup a PPTP connection in Fedora that mimics the default for a windows VPN (PPTP) connection, do the following: 
  • Add PPTP VPN connection
  • Set host, username and password
  • Click advanced
  • Check only MSCHAPv2 for authentication methods
  • Click use Point-to-Point encryption (MPPE)
  • Leave Security at "All Available"
  • Under IPv4 settings
  • Under routes
  • Uncheck "use this resource only for resources on its network"

Install Webmin on EC2 Image

To install webmin on an ec2 instance perform the following:

  • set password for root user
    • passwd
  • cd /usr/tmp
  • wget http://downloads.sourceforge.net/project/webadmin/webmin/1.480/webmin-1.480-1.noarch.rpm?use_mirror=softlayer
  • Install RPM
    • rpm -U webmin-1.350-1.noarch.rpm
  • chkconfig webmin on
  • service webmin start
  • http://ec2-174-129-174-74.compute-1.amazonaws.com:10000/

Saving Customized AMI in S3

From: http://robrohan.com/2009/01/30/saving-a-customised-linux-amazon-instance-ec2-and-s3/

The workflow being, you bring up an AMI, install a bunch of software, configure it how you need it, and then you need to store your new image so you can bring it up again.
Saving a custom AMI isn’t too difficult once you know how, but it takes a bit of digging around to find out how all the pieces work. I am going to assume you have an EC2 and S3 account already, know how to bring up an EC2 instance, have your Amazon API Tools installed on your Mac or Linux desktop, have your private and cert key’s installed, and have your aws access key id, aws secret access key, and Amazon account number handy (the account number is under your name on the Amazon account page. It looks like XXXX-XXXX-XXXX).
The key concept that had me stumped for a bit is you have to do things on both your local desktop and on the AMI base server as it’s running.
Find a base image
In Elasticfox find an image you want to use as a base. I grabbed an Ubuntu 8.04 instance, but any Linux instance should work with little modification to this walkthrough. Once you find a suitable instance, Launch an instance of the AMI.
Connect to the instance
SSH into the box either by the Elasticfox right click “Connect to Public DNS Name”, or by hand. Make sure the connection works and it looks like a nice starting point for your image.
Copy your keys
If the box looks ok, you’ll need to copy your private key and cert key over to the instance. This is so Amazon knows it’s yours and allows Amazon to start the instance. It is very important to copy the keys into the /mnt directory because that directory will not be saved with your new image. If you put the keys somewhere else, they might get saved and the next person that starts up your AMI will have your keys… not good.
You can copy the keys to the running instance with the following command (replacing values where apropos)
$ scp -i /Users/robrohan/ec2-keys/id_my_rsa_key ~/.ec2/pk-STRINGOFTHIRTYTWOLETTERSORDIGITS.pem ~/.ec2/cert-STRINGOFTHIRTYTWOLETTERSORDIGITS.pem root@[your_instance_public_address]:/mnt
Install tools on the AMI
Now switch back to the SSH window that you have connected to the AMI. We need to install a few Amazon tools on the instance to allow you to create another AMI and store it. Depending on what base you installed you might need to install other tools. For example, I had to install the following:
# apt-get install zip unzip ruby openssl libopenssl-ruby curl
You’ll know in a second if you are missing something else ^_^.
Download the Amazon AMI tools onto the server.
# curl http://s3.amazonaws.com/ec2-downloads/ec2-ami-tools.zip > ec2-ami-tools.zip
Now you need to unzip the tools and put them somewhere. You may have a specific way you like to do it, but this is how I did it command by command (sorry there is no explanation here, but you should be able to follow this)
# cd
# curl http://s3.amazonaws.com/ec2-downloads/ec2-ami-tools.zip > ec2-ami-tools.zip
# mkdir ec2
# cp ec2-ami-tools.zip ec2
# cd ec2
# unzip ec2-ami-tools.zip
# ln -s ec2-ami-tools-* current
# vi ~/.bashrc
add the following lines to the end of the .bashrc file
export EC2_AMITOOL_HOME=~/ec2/current
export PATH=${PATH}:~/ec2/current/bin
And then re-initialise the configuration file
# source ~/.bashrc
You should be able to run the following command and not get an error:
# ec2-bundle-vol --help
Create your AMI
Now we are going to take a snap shot of the running server. While still on the server run the following command:
# ec2-bundle-vol -d /mnt -k /mnt/pk-STRINGOFTHIRTYTWOLETTERSORDIGITS.pem -c /mnt/cert-STRINGOFTHIRTYTWOLETTERSORDIGITS.pem -u XXXXXXXXXXXX
Where XXXXXXXXXXXX is your Amazon account number without the dashes.
This command will take a while to run, and it takes longer the larger the instance – go make a cup of coffee and relax for a bit.
Once it’s done make sure there are no errors. The first time I built one I had an error (something about the loopback interface being horked). I continued on only to find I couldn’t connect to the instance (which saved, and started ok).
One error you might get that seems to be ok is “Unable to read instance meta-data for product-codes”. I am guessing that has something to to with proprietary OSs.
Save your new AMI to S3
You now have an AMI of your very own, but we need to save it to S3 so you can shut down your current AMI and start up your new one.
While still SSH’ed into the server using the following command to send your AMI to your S3 account:
# ec2-upload-bundle -b [your-s3-bucket] -m /mnt/image.manifest.xml -a [aws-access-key-id] -s [aws-secret-access-key]
S3Hub AMI bits
It’s better to create a bucket before you issue this command. You can use any standard S3 desktop tool. If the bucket doesn’t exist, it should create the bucket for you though. The keys are those crazy long keys you use to access S3.
Register the AMI
Ok, almost done. You’ve now created an AMI and stored it on S3, but you still have to tell EC2 where the AMI is located so you can create an instance of it.
Go back to your desktop, and issue the command:
$ ec2-register [your_bucket]/image.manifest.xml
The command should respond with an AMI ID like ami-259d7a4c. You’ll use this key to start up an instance of your AMI.
Start up your AMI
If you go back into Elasticfox and hit the refresh button on the Machine Images area, you can then type in your new AMI in the search box, hit enter and see your image. At that point you can right click and do “Launch instance of this AMI”… the rest should be old hat.
You’re not done yet…
So you went through that, now you probably have to do it again this time setting up all the software and configurations you want. If you’re going to trash that instance we just built (or any future versions), you need to de-register the AMI before you remove the files from S3. It’s very easy, you just:
$ ec2-deregister [ami id]
The command should just echo back the ami-id. You can then delete the files off S3 using whatever tool suits you best.
So yeah, quite a bit of steps. But most make sense, and once you do it a few times it’s not too bad. But it was hard enough that I made this quick reminder for myself ^_^

Install Openser on EC2 Image

yum install unixODBC mysql mysql-server mysql-devel gcc bison flex
chkconfig mysqld on
service mysqld start
mysqladmin -u root password 'pass'

#to log into mysql server
mysql -u root -p
drop database test;

yum install mysql-connector-odbc
wget http://www.kamailio.org/pub/kamailio/latest/src/kamailio-1.5.1-tls_src.tar.gz
tar xvfz kamailio-1.5.1-tls_src.tar.gz
cd kamailio-1.5.1
edit Makefile and uncomment Tls=1 to compile with tls
make sure openssl, openssl-devel are installed (ec2 already are)
from http://www.kamailio.org/docs/tls-devel.html#id2470286
To enable the server_name (aka SNI) TLS extension an openssl version with TLS extension support must be installed, e.g. openssl 0.9.9 or openssl 0.9.8h. When compiling OpenSSL, run "./configure --enable-tlsext".

1.4.1. Dependencies of external libraries

Kamailio TLS support requires OpenSSL from http://www.openssl.org. For FreeBSD, you can either use the system OpenSSL or OpenSSL from the ports system. In Linux, it's distributed in the following packages:

  • openssl or libssl >= 0.9.6

  • openssl-dev or libssl-dev
make all include_modules="db_mysql"
make install include_modules="db_mysql"

nano /user/local/etc/kamailio/kamctlrc
uncomment SIP_DOMAIN=kamailio.local
uncomment DBENGINE=MYSQL
uncomment DBHOST=localhost

/usr/local/sbin/kamdbctl create
This will create a database named 'openser' and will add a Mysql user 'openser' with full access to it. The default password is 'openserrw', do change it before (by editing /usr/local/etc/kamctlrc) or immediately after you create the database.


nano /etc/kamailio/kamailio.cfg and uncomment the following lines set mydomain.com to your domain (kamailio.local):
loadmodule "db_mysql.so"

loadmodule "auth.so"
loadmodule "auth_db.so"

modparam("usrloc", "db_mode", 2)
modparam("usrloc", "db_url", "mysql://openser:openserrw@localhost/openser")

modparam("auth_db", "calculate_ha1", yes)
modparam("auth_db", "password_column", "password")
modparam("auth_db", "db_url", "mysql://openser:openserrw@localhost/openser")
modparam("auth_db", "load_credentials", "")

if (!www_authorize("mydomain.com", "subscriber"))
{
www_challenge("mydomain.com", "0");
exit;
}

if (!check_to())
{
sl_send_reply("403","Forbidden auth ID");
exit;
}


In the file /etc/odbcinst.ini  you must add:

# Driver from the MyODBC package
# Setup from the unixODBC package
[MySQL]
Description     = ODBC for MySQL
Driver          = /usr/lib/libmyodbc3.so
Setup           = /usr/lib/libodbcmyS.so
FileUsage = 1



kamctl start



cd /usr/local/src
wget http://b2bua.org/chrome/site/rtpproxy-1.2.0.tar.gz
tar -xf rtpproxy-1.2.0.tar.gz
cd rtpproxy-1.2.0
./configure
make
make install

adduser rtpproxy -d /home/rtpproxy -s /bin/false


to start where 174.129.12.103 is the ip of the server
rtpproxy -l 174.129.12.103 -s udp:localhost:7722 -u rtpproxy

to stop
pid= cat "/var/run/rtpproxy.pid"  2>/dev/null
kill pid


Did you check if rtpproxy is running

if it is running try to use force_sock function as shown below
modparam("nathelper", "force_socket", "udp:localhost:8899")

another option to run ur RTP proxy is

rtpproxy -F -l your-public-ip  -s udp:localhost:port-no
rtpproxy -F -l 174.129.12.103  -s udp:127.0.0.1:7722


if u use the above command to start rtp proxy. then change ur cfg file like
this
modparam("nathelper", "rtpproxy_sock", "udp:127.0.0.1:port-no")
modparam("nathelper", "force_socket", "udp:localhost:port-no")




yum install ngrep
ngrep -d any port 5060

Automate SSH in Linux to EC2 Image

To automate the process of SSH'ing into an EC2 image so you don't have to reference the keys everytime, you must edit the config files for OpenSSH. OpenSSH looks at the config files and reads the first value given and ignores any overwrites later. /[username]/.ssh/config is the user specfic config file that has to be configured

 and /etc/ssh/ssh_config is the general config file.

Place the following in the config file:
HOST *.amazonaws.com
IdentityFile location_of_pem_key_file_from_ec2
User root

Then run:
chmod 600 [location of pem key file from ec2]

Now to SSH to an EC2 image all you have to do is run:
ssh ec2-75-101-239-13.compute-1.amazonaws.com

Installing X-lite on Fedora

  • Download the linux distro of x-lite 
  • Download the following dependent pacakages
    • yum -y install compat-libstdc++-33 compat-libstdc++-296

Start Services Automatically in Linux

  • add the script to be executed at startup to /etc/rc.d/rc.local
  • if you dont want to follow the symlinks in /etc/rc.d/* directories you can use the graphical interface to configure
  • The following cli commands will also make services start automatically
    • chkconfig snmpd --list
    • chkconfig snmpd on

Create Mysql Trigger

  • Connect to mysql server
    • mysql --password=******
  •  Select Database
    • use [database name] 
  • Create Trigger
    • DELIMITER //
      CREATE TRIGGER add_mediatrix_ports after insert on mediatrix_boxes
      FOR EACH ROW BEGIN
      declare l_loop int default 1;
      while l_loop
      insert into mediatrix_ports (mediatrix_boxid, port, operational, date_created, created_userid, date_modified, modified_userid) VALUES (new.id, l_loop, 1, "2009-07-07", 1, "2009-07-07 16:20:23", 1);
      set l_loop := l_loop + 1;
      end while//
    • DELIMITER //
      create trigger insert_tut_line after insert on tut_slots for each row
      begin
      declare l_loop int default 1;
      while l_loop < 9 do
      INSERT INTO `tut_lines` (tut_slotid, line, date_created, created_userid, date_modified, modified_userid, operational) VALUES (new.id, l_loop, '2007-05-24', 1, '2009-07-07 13:39:32', 1, 1);
      set l_loop := l_loop + 1;
      end while;
      end;

Setting up X-Lite Softphone with Broadsoft

  • Configuring Broadosoft
    • Create a device profile using the "Generic SIP Phone" template
    • Create and assign a user profile to newly created device
  • Configuring X-lite
    • Display Name: Can be anything
    • Username:User profile line/portid
    • Password: authentication password in Broadsoft
    • Authorization username: authentication username in Broadsoft
    • Domain: mars.pbx-change.com
    • Use a proxy: sbc.pbx-change.com

Configuring Mysql to Allow External Connections

Setting up Mysql to allow users to connect externally

1. You have to specifically define how users can connect to the database.

GRANT ALL PRIVILEGES ON dbname.* TO username@'IP' IDENTIFIED BY 'password';
GRANT ALL PRIVILEGES ON dbname.* TO username@'%' IDENTIFIED BY 'password';
GRANT ALL PRIVILEGES ON dbname.* TO username@'localhost' IDENTIFIED BY 'password';
GRANT ALL PRIVILEGES ON dbname.* TO username@'127.0.0.1' IDENTIFIED BY 'password';

2. Open port 3306 in firewalls

3.) to grant httpd the access to the network. To allow the httpd dameon to connect to port 3306 when you've told zend to connect to the database externally
setsebool -P httpd_can_network_connect=1

Installing Apache on Fedora

  • Restart Apache
    • apachectl restart
  • Edit httpd.conf
    • nano /etc/httpd/conf/httpd.conf
  • Make sure mod rewrite is loaded
    • uncomment mod_rewrite line in httpd.conf
  • When installing php, use installer and add the following lines to httpd.conf
    • LoadModule php5_module "c:/program files/php/php5apache2_2.dll"
    • AddType application/x-httpd-php .php .php5
    • PHPIniDir "c:/program files/php"

Setting Up Eclipse PDT, Subversion and Zend Framework

  1. Download http://www.eclipse.org/pdt/downloads/ PDT all-in-ones that include eclipse and the PDT, and mylyn plugins
  2. Download and install subclipse by adding http://subclipse.tigris.org/update_1.6.x as an update site for eclipse in eclipse under "Help".. "Install New Software"... "Add"
  3. Download and install Zend Debugger by adding http://downloads.zend.com/pdt as an update site
  4. Download and install mysql workbench
  5. In eclipse create a new PHP project and import all of your files into it. Then right click on the project Team->Share->SVN
  6. For other people to get a working copy in eclipse: File->New->SVN->Check out existing project

SVN Management

Managing SVN Server
svnadmin is a management tool that can be used to manage any svn repository. When using svnadmin it is necessary to include the directory of the target repository.

Use:
svnadmin [cmd]
svn [cmd] appears to be for client actions

Setting Up SVN
  • Install subversion.
  • Put the bin folder (C:\program files\subversion\bin) in the path system variable
  • Decide the location of the repository on disk and make the appropriate folders. (mkdir c:\svn\repository)
  • Create the repository (svnadmin create c:\svn\repository)
  • Open the apache configuration file httpd.conf (c:\apache\conf\httpd.conf)
  • Make sure that the module mod_dav is loaded in httpd.conf and that the module file is also present under modules directory.
  • Add the following to the httpd.conf file (if necessary add it under the appropriate virtual host)

    DAV svn
    SVNPath c:\svn\repository
    AuthType Basic
    AuthName "Name of Authentication popup window"
    AuthUserFile c:\path\to\auth\file probable c:\svn\svn_apache_auth
    Require valid-use
  • Create the auth file
    htpasswd -cmd c:\svn\svn_apache_auth {user-name}
    -c
    option creates a new htpasswd file.
    -m
    encrypts the password with an MD5 algorithm.
    -d
    encrypts the password with a CRYPT algorithm.
    **Note don't use -c after the file has been created when wishing to add additional users
Start the subversion server

Your Subversion client software will need a server with which it can talk. This is the svnserve executable. It's also possible to go directly to your file system and not use a server, but we're going to set this up so that you can access your files from other machines on your network. The -d option tells svnserve to run as a daemon.


    echo "I like PHP";
svnserve -d -r c:\svn-repo



Deleting a Repository
the correct way to delete a repository is just to delete the directory it's stored in.