702da5a1b95f44ecffc2549ba99254c5efc38bbf
[freeside.git] / httemplate / docs / upgrade8.html
1 <head>
2   <title>Upgrading to 1.4.0</title>
3 </head>
4 <body>
5 <h1>Upgrading to 1.4.0 from 1.3.1</h1>
6 <ul>
7   <li>If migrating from less than 1.3.1, see these <a href="upgrade7.html">instructions</a> first.
8   <li>Back up your data and current Freeside installation.
9   <li>Install <a href="http://www.apache-asp.org/">Apache::ASP</a> or <a href="http://www.masonhq.com/">HTML::Mason</a>.
10 </ul>
11 <table>
12   <tr>
13     <th>Apache::ASP</th><th>Mason</th>
14   </tr>
15   <tr>
16     <td><ul>
17       <li>Run <tt>make aspdocs</tt>
18       <li>Copy <tt>aspdocs/</tt> to your web server's document space.
19       <li>Create a <a href="http://www.apache-asp.org/config.html#Global">Global</a> directory, such as <tt>/usr/local/etc/freeside/asp-global/</tt>
20       <li>Copy <tt>htetc/global.asa</tt> to the Global directory.
21       <li>Configure Apache for the Global directory and to execute .cgi files using Apache::ASP.  For example:
22 <font size="-1"><pre>
23 &lt;Directory /usr/local/apache/htdocs/freeside-asp&gt;
24 &lt;Files ~ (\.cgi)&gt;
25 AddHandler perl-script .cgi
26 PerlHandler Apache::ASP
27 &lt;/Files&gt;
28 &lt;Perl&gt;
29 $MLDBM::RemoveTaint = 1;
30 &lt;/Perl&gt;
31 PerlSetVar Global /usr/local/etc/freeside/asp-global/
32 &lt;/Directory&gt;
33 </pre></font>
34     </ul></td>
35     <td><ul>
36       <li>Run <tt>make masondocs</tt>
37       <li>Copy <tt>masondocs/</tt> to your web server's document space.
38       <li>Copy <tt>htetc/handler.pl</tt> to your web server's configuration directory.
39       <li>Edit <tt>handler.pl</tt> and set an appropriate <tt>data_dir</tt>, such as <tt>/usr/local/etc/freeside/mason-data</tt>
40       <li>Configure Apache to use the <tt>handler.pl</tt> file and to execute .cgi files using HTML::Mason.  For example:
41 <font size="-1"><pre>
42 &lt;Directory /usr/local/apache/htdocs/freeside-mason&gt;
43 &lt;Files ~ (\.cgi)&gt;
44 AddHandler perl-script .cgi
45 PerlHandler HTML::Mason
46 &lt;/Files&gt;
47 &lt;Perl&gt;
48 require "/usr/local/apache/conf/handler.pl";
49 &lt;/Perl&gt;
50 &lt;/Directory&gt;
51 </pre></font>
52     </ul></td>
53   </tr>
54 </table>
55 <ul>
56   <li>Change to the FS directory in the new tarball, and build and install the
57       Perl modules:
58     <pre>
59 $ cd FS/
60 $ perl Makefile.PL
61 $ make
62 $ su
63 # make install UNINST=1</pre>
64   <li>If you are using PostgreSQL, apply the following changes to your database:
65 <pre>
66 CREATE UNIQUE INDEX agent_pkey ON agent ( agentnum );
67 CREATE UNIQUE INDEX agent_type_pkey agent_type ( typenum );
68 CREATE UNIQUE INDEX cust_bill_pkey ON cust_bill ( invnum );
69 CREATE UNIQUE INDEX cust_credit_pkey ON cust_credit ( crednum );
70 CREATE UNIQUE INDEX cust_main_pkey ON cust_main ( custnum );
71 CREATE UNIQUE INDEX cust_main_county_pkey ON cust_main_county ( taxnum );
72 CREATE UNIQUE INDEX cust_main_invoice_pkey ON cust_main_invoice ( destnum );
73 CREATE UNIQUE INDEX cust_pay_pkey ON cust_pay ( paynum );
74 CREATE UNIQUE INDEX cust_pkg_pkey ON cust_pkg ( pkgnum );
75 CREATE UNIQUE INDEX cust_refund_pkey ON cust_refund ( refundnum );
76 CREATE UNIQUE INDEX cust_svc_pkey ON cust_svc ( svcnum );
77 CREATE UNIQUE INDEX domain_record_pkey ON domain_record ( recnum );
78 CREATE UNIQUE INDEX nas_pkey ON nas ( nasnum );
79 CREATE UNIQUE INDEX part_pkg_pkey ON part_pkg ( pkgpart );
80 CREATE UNIQUE INDEX part_referral_pkey ON part_referral ( refnum );
81 CREATE UNIQUE INDEX part_svc_pkey ON part_svc ( svcpart );
82 CREATE UNIQUE INDEX port_pkey ON port ( portnum );
83 CREATE UNIQUE INDEX prepay_credit_pkey ON prepay_credit ( prepaynum );
84 CREATE UNIQUE INDEX session_pkey ON session ( sessionnum );
85 CREATE UNIQUE INDEX svc_acct_pkey ON svc_acct ( svcnum );
86 CREATE UNIQUE INDEX svc_acct_pop_pkey ON svc_acct_pop ( popnum );
87 CREATE UNIQUE INDEX svc_acct_sm_pkey ON svc_acct_sm ( svcnum );
88 CREATE UNIQUE INDEX svc_domain_pkey ON svc_domain ( svcnum );
89 CREATE UNIQUE INDEX svc_www_pkey ON svc_www ( svcnum );
90 CREATE UNIQUE INDEX type_pkgs_pkey ON type_pkgs ( typenum );
91 </pre>
92   <li>If you wish to enable service/shipping addresses, apply the following
93       changes to your database:
94 <pre>
95 ALTER TABLE cust_main ADD COLUMN ship_last varchar(80) NULL;
96 ALTER TABLE cust_main ADD COLUMN ship_first varchar(80) NULL;
97 ALTER TABLE cust_main ADD COLUMN ship_company varchar(80) NULL;
98 ALTER TABLE cust_main ADD COLUMN ship_address1 varchar(80) NULL;
99 ALTER TABLE cust_main ADD COLUMN ship_address2 varchar(80) NULL;
100 ALTER TABLE cust_main ADD COLUMN ship_city varchar(80) NULL;
101 ALTER TABLE cust_main ADD COLUMN ship_county varchar(80) NULL;
102 ALTER TABLE cust_main ADD COLUMN ship_state varchar(80) NULL;
103 ALTER TABLE cust_main ADD COLUMN ship_zip varchar(10) NULL;
104 ALTER TABLE cust_main ADD COLUMN ship_country char(2) NULL;
105 ALTER TABLE cust_main ADD COLUMN ship_daytime varchar(20) NULL;
106 ALTER TABLE cust_main ADD COLUMN ship_night varchar(20) NULL;
107 ALTER TABLE cust_main ADD COLUMN ship_fax varchar(12) NULL;
108 </pre>
109   <li>If you wish to enable customer comments, apply the following change to
110       your database:
111 <pre>
112 ALTER TABLE cust_main ADD COLUMN comments varchar NULL;
113 </pre>
114   <li>Run bin/dbdef-create.
115 </body>