summaryrefslogtreecommitdiff
path: root/httemplate/docs/billing.html
blob: dcb90208a1bfe79b8f882faa3b4e999058db5e60 (plain)
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
66
67
68
69
70
<head>
  <title>Billing</title>
</head>
<body>
  <h1>Billing</h1>
  <ul>
    <li>To enable billing, you <b>must</b> create an <a href="config.html#invoice_template">invoice_template</a> configuration file.  An example file is available in the <i>conf/</i> directory of the distribution.  You also need to create an <a href="config.html#lpr">lpr</a> configuration file to enable postal invoices.
    <ul>
      <li>Optional: Invoice template customization
        <ul>
          <li>See the <a href="http://search.cpan.org/doc/MJD/Text-Template-1.42/Template.pm">Text::Template</a> documentation for details on the substitution language.
          <li>You <b>must</b> call the invoice_lines() function at least once - pass it a number of lines, and it returns a list of array references, each of two elements: a service description column, and a price column.
          <li>In addition, the following variables are available:
            <ul>
              <li>$invnum - invoice number
              <li>$date - as a UNIX timestamp (see <a href="http://search.cpan.org/doc/GBARR/TimeDate-1.09/lib/Date/Format.pm">Date::Format</a> for conversion functions).
              <li>$page - current page
              <li>$total_pages - total pages
              <li>@address - A six-element array containing the customer name, company, and address.
              <li>$overdue - true if this invoice is overdue
            </ul>
        </ul>
    </ul>
    <li>You can bill individual customers by clicking on the <i>Bill now</i> link on the main customer view.
    <li> The <b>freeside-bill</b> script can be run daily to bill all customers. (link to manpage!)  Usage:<pre>freeside-bill [ -c [ -p ] [ -a ] [ -i ] ] [ -d <i>date</i> ] <i>user</i></pre>
      <ul>
        <li>-c: Turn on collecting (you probably want this).
        <li>-p: Apply unapplied payments and credits before collecting (you probably want this too)
        <li>-a: Call collect even if there isn't a new invoice (probably a bad idea for daily use)
        <li>-i: Real-time billing (as opposed to bacth billing).  Only relevant for credit cards.
        <li>-d: Pretend it is <i>date</i> (parsed by <a href="http://search.cpan.org/doc/GBARR/TimeDate-1.09/lib/Date/Parse.pm">Date::Parse</a>)
        <li>user: as setup with freeside-adduser
      </ul>
      <br><br>Batch credit card processing
      <ul>
        <li>After this script is run, a credit card batch will be in the <a href="schema.html#cust_pay_batch">cust_pay_batch</a> table.  Export this table to your credit card batching.
        <li>When your batch completes, erase the cust_pay_batch records in that batch and add any necessary paymants to the <a href="schema.html#cust_pay">cust_pay</a> table.  Example code to add payments is:
        <pre>use FS::cust_pay;

# loop over all records in batch

my $payment=create FS::cust_pay (
  'invnum' => $invnum,
  'paid' => $paid,
  '_date' => $_date,
  'payby' => $payby,
  'payinfo' => $payinfo,
  'paybatch' => $paybatch,
);

my $error=$payment->insert;
if ( $error ) {
  #process error
}

# end loop
</pre>
All fields except paybatch are contained in the cust_pay_batch table.  You can use paybatch field to track particular batches and/or particular transactions within a batch.<br><br>
        <li>The <b>freeside-print-batch</b> script can print or email pending credit card batches for manual entry.  Usage: freeside-print-batch [-v] [-p] [-e] [-a] [-d] <i>user</i>
          <ul>
            <li>-v: Verbose - Prints records to STDOUT.
            <li>-p: Print to printer lpr as found in the conf directory.
            <li>-e: Email output to user found in the Conf email file.
            <li>-a: Automatically pays all records in cust_pay_batch.  Use -d with this option usually.
            <li>-d: Delete - Pays account and deletes record from cust_pay_batch.
          </ul>
      </ul>
    <li>The <b>freeside-overdue</b> script can list, add postal invoicing, suspend or cancel overdue and/or expired accounts (link to manpage!).
  </ul>
</body>