Jeden DATEV-Export in ein eigenes, eindeutig benanntes Verzeichnis schreiben, damit...
[kivitendo-erp.git] / bin / mozilla / datev.pl
1 #=====================================================================
2 # Lx-Office ERP
3 # Copyright (c) 2004
4 #
5 #  Author: Philip Reetz
6 #   Email: p.reetz@linet-services.de
7 #     Web: http://www.lx-office.org
8 #
9 #
10 # This program is free software; you can redistribute it and/or modify
11 # it under the terms of the GNU General Public License as published by
12 # the Free Software Foundation; either version 2 of the License, or
13 # (at your option) any later version.
14 #
15 # This program is distributed in the hope that it will be useful,
16 # but WITHOUT ANY WARRANTY; without even the implied warranty of
17 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18 # GNU General Public License for more details.
19 # You should have received a copy of the GNU General Public License
20 # along with this program; if not, write to the Free Software
21 # Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
22 #======================================================================
23 #
24 # Datev export module
25 #
26 #======================================================================
27
28 use POSIX qw(strftime getcwd);
29 use Archive::Zip qw(:ERROR_CODES :CONSTANTS);
30
31 use SL::Common;
32 use SL::DATEV;
33
34 1;
35
36 # end of main
37
38 require "bin/mozilla/common.pl";
39
40 sub continue { call_sub($form->{"nextsub"}); }
41
42 sub export {
43   $lxdebug->enter_sub();
44
45   $auth->assert('datev_export');
46
47   $form->{title} = $locale->text("DATEX - Export Assistent");
48
49   DATEV->get_datev_stamm(\%myconfig, \%$form);
50   $form->header;
51
52   print qq|
53 <body>
54
55 <form method=post action=$form->{script}>
56
57
58 <table width=100%>
59   <tr>
60     <th class=listtop>$form->{title}</th>
61   </tr>
62   <tr>
63     <th align=left>| . $locale->text("DATEV Angaben") . qq|</th>
64   </tr>
65   <tr height="5"></tr>
66   <tr valign=top>
67     <td>
68       <table>
69         <tr>
70           <td align=left nowrap>| . $locale->text("Beraternummer") . qq|</td>
71           <td><input name=beraternr size=10 maxlength=7 value="$form->{beraternr}"></td>
72
73           <td align=left nowrap>| . $locale->text("DFV-Kennzeichen") . qq|</td>
74           <td><input name=dfvkz size=5 maxlength=2 value="$form->{dfvkz}"></td>
75         </tr>
76         <tr>
77           <td align=left nowrap>| . $locale->text("Beratername") . qq|</td>
78           <td><input name=beratername size=10 maxlength=9 value="$form->{beratername}"></td>
79
80           <td align=left nowrap>| . $locale->text("Password") . qq|</td>
81           <td><input name=passwort size=5 maxlength=4 value="$form->{passwort}"></td>
82         </tr>
83         <tr>
84           <td align=left nowrap>| . $locale->text("Mandantennummer") . qq|</td>
85           <td><input name=mandantennr size=10 maxlength=5 value="$form->{mandantennr}"></td>
86
87           <td align=left nowrap>| . $locale->text("Medium Number") . qq|</td>
88           <td><input name=datentraegernr size=5 maxlength=3 value="$form->{datentraegernr}"></td>
89         </tr>
90         <tr>
91           | . # OBE-Export noch nicht implementiert! <td><input checked name=kne type=checkbox class=checkbox value=1> | . $locale->text("Kontonummernerweiterung (KNE)") . qq|</td>
92     qq|<td><input type="hidden" name="kne" value="1"></td>
93           <td></td>
94
95           <td align=left nowrap>| . $locale->text("Abrechnungsnummer") . qq|</td>
96           <td><input name=abrechnungsnr size=5 maxlength=3 value="$form->{abrechnungsnr}"></td>
97         </tr>
98
99         <tr>
100           <td><input name=exporttype type=radio class=radio value=0 checked> |
101     . $locale->text("Export Buchungsdaten") . qq|</td>
102           <td></td>
103
104           <td><input name=exporttype type=radio class=radio value=1> |
105     . $locale->text("Export Stammdaten") . qq|</td>
106           <td></td>
107         </td>
108       </table>
109     </td>
110   </tr>
111   <tr>
112     <td><hr size=3 noshade></td>
113   </tr>
114 </table>
115
116 <input type=hidden name=nextsub value=export2>
117
118 <br>
119 <input type=submit class=submit name=action value="|
120     . $locale->text('Continue') . qq|">
121 </form>
122
123 </body>
124 </html>
125 |;
126   $lxdebug->leave_sub();
127 }
128
129 sub export2 {
130   $lxdebug->enter_sub();
131
132   $auth->assert('datev_export');
133
134   if ($form->{exporttype} == 0) {
135     &export_bewegungsdaten();
136   } else {
137     &export_stammdaten();
138   }
139   $lxdebug->leave_sub();
140 }
141
142 sub export_bewegungsdaten {
143   $lxdebug->enter_sub();
144
145   $auth->assert('datev_export');
146
147   $form->{title} = $locale->text("DATEX - Export Assistent");
148
149   $form->{allemonate} =
150       qq|<option value=1>|
151     . $locale->text('January')
152     . qq|</option>
153                          <option value=2>|
154     . $locale->text('February') . qq|</option>
155                          <option value=3>|
156     . $locale->text('March') . qq|</option>
157                          <option value=4>|
158     . $locale->text('April') . qq|</option>
159                          <option value=5>|
160     . $locale->text('May') . qq|</option>
161                          <option value=6>|
162     . $locale->text('June') . qq|</option>
163                          <option value=7>|
164     . $locale->text('July') . qq|</option>
165                          <option value=8>|
166     . $locale->text('August') . qq|</option>
167                          <option value=9>|
168     . $locale->text('September') . qq|</option>
169                          <option value=10>|
170     . $locale->text('October') . qq|</option>
171                          <option value=11>|
172     . $locale->text('November') . qq|</option>
173                          <option value=12>|
174     . $locale->text('December') . qq|</option>|;
175
176   $form->{allequartale} =
177       qq|<option selected value=1>|
178     . $locale->text('I')
179     . qq|</option>
180                          <option value=2>| . $locale->text('II') . qq|</option>
181                          <option value=3>|
182     . $locale->text('III') . qq|</option>
183                          <option value=4>|
184     . $locale->text('IV') . qq|</option>|;
185   $form->{"jsscript"} = 1;
186   $form->header;
187
188   print qq|
189 <body>
190
191 <form method=post action=$form->{script}>
192
193
194 <table width=100%>
195   <tr>
196     <th class=listtop>$form->{title}</th>
197   </tr>
198   <tr>
199     <th align=left>| . $locale->text("Zeitraum") . qq|</th>
200   </tr>
201   <tr height="5"></tr>
202   <tr valign=top>
203     <td>
204       <table>
205         <tr>
206           <td align=left><input checked name=zeitraum class=radio type=radio value=monat>&nbsp;</td><td align=left>|
207     . $locale->text('Monat') . qq|</td>
208           <td align=left></td>
209           <td align=left></td>
210           <td align=left><select name=monat>$form->{allemonate}</select></td>
211         </tr>
212         <tr>
213           <td align=left><input name=zeitraum class=radio type=radio value=quartal>&nbsp;</td><td align=left>|
214     . $locale->text('Quartal') . qq|</td>
215           <td align=left></td>
216           <td align=left></td>
217           <td align=left><select name=quartal>$form->{allequartale}</select></td>
218         </tr>
219         <tr>
220           <td align=left><input name=zeitraum class=radio type=radio value=zeit>&nbsp;</td><td align=left>|
221     . $locale->text('Datum von') . qq|</td>
222           <td align=left><input id=transdatefrom name=transdatefrom size=10>
223             <input type="button" name="transdatefrom" id="trigger_transdatefrom" value="?"></td>
224           <td align=left>| . $locale->text('bis') . qq|</td>
225           <td align=left><input id=transdateto name=transdateto size=10>
226             <input type="button" name="transdateto" id="trigger_transdateto" value="?"></td>
227         </tr>
228       </table>
229     </td>
230   </tr>
231   <tr>
232     <td><hr size=3 noshade></td>
233   </tr>
234 </table>
235
236 | . $form->write_trigger(\%myconfig, 2,
237                          "transdatefrom", "BL", "trigger_transdatefrom",
238                          "transdateto", "BL", "trigger_transdateto") . qq|
239
240 <input type=hidden name=beraternr value="$form->{beraternr}">
241 <input type=hidden name=dfvkz value="$form->{dfvkz}">
242 <input type=hidden name=beratername value="$form->{beratername}">
243 <input type=hidden name=passwort value="$form->{passwort}">
244 <input type=hidden name=mandantennr value="$form->{mandantennr}">
245 <input type=hidden name=datentraegernr value="$form->{datentraegernr}">
246 <input type=hidden name=kne value="$form->{kne}">
247 <input type=hidden name=abrechnungsnr value="$form->{abrechnungsnr}">
248
249 <input type=hidden name=exporttype value="$form->{exporttype}">
250
251 <input type=hidden name=nextsub value=export3>
252
253 <br>
254 <input type=submit class=submit name=action value="|
255     . $locale->text('Continue') . qq|">
256 </form>
257
258 </body>
259 </html>
260 |;
261
262   $lxdebug->leave_sub();
263 }
264
265 sub export_stammdaten {
266   $lxdebug->enter_sub();
267
268   $auth->assert('datev_export');
269
270   $form->{title} = $locale->text("DATEX - Export Assistent");
271
272   $form->header;
273
274   print qq|
275 <body>
276
277 <form method=post action=$form->{script}>
278 <table width=100%>
279   <tr>
280     <th class=listtop>$form->{title}</th>
281   </tr>
282   <tr>
283     <th align=left>| . $locale->text("Konten") . qq|</th>
284   </tr>
285   <tr height="5"></tr>
286   <tr valign=top>
287     <td>
288       <table>
289         <tr>
290           <td align=left>| . $locale->text('Von Konto: ') . qq|</td>
291           <td align=left><input name=accnofrom size=8 maxlength=8></td>
292         </tr>
293         <tr>
294           <td align=left>| . $locale->text('Bis Konto: ') . qq|</td>
295           <td align=left><input name=accnoto size=8 maxlength=8></td>
296         </tr>
297       </table>
298     </td>
299   </tr>
300   <tr>
301     <td><hr size=3 noshade></td>
302   </tr>
303 </table>
304 <input type=hidden name=beraternr value="$form->{beraternr}">
305 <input type=hidden name=dfvkz value="$form->{dfvkz}">
306 <input type=hidden name=beratername value="$form->{beratername}">
307 <input type=hidden name=passwort value="$form->{passwort}">
308 <input type=hidden name=mandantennr value="$form->{mandantennr}">
309 <input type=hidden name=datentraegernr value="$form->{datentraegernr}">
310 <input type=hidden name=kne value="$form->{kne}">
311 <input type=hidden name=abrechnungsnr value="$form->{abrechnungsnr}">
312
313 <input type=hidden name=exporttype value="$form->{exporttype}">
314
315 <input type=hidden name=nextsub value=export3>
316
317 <br>
318 <input type=submit class=submit name=action value="|
319     . $locale->text('Continue') . qq|">
320 </form>
321
322 </body>
323 </html>
324 |;
325
326   $lxdebug->leave_sub();
327 }
328
329 sub export3 {
330   $lxdebug->enter_sub();
331
332   $auth->assert('datev_export');
333
334   DATEV::clean_temporary_directories();
335
336   DATEV->save_datev_stamm(\%myconfig, \%$form);
337
338   my $link = "datev.pl?action=download&download_token=";
339
340   if ($form->{kne}) {
341     my $result = DATEV->kne_export(\%myconfig, \%$form);
342     if ($result && @{ $result->{filenames} }) {
343       $link .= Q($result->{download_token});
344
345       print(qq|<br><b>| . $locale->text('KNE-Export erfolgreich!') . qq|</b><br><br><a href="$link">Download</a>|);
346
347     } else {
348       $form->error("KNE-Export schlug fehl.");
349     }
350   } else {
351     # OBE-Export nicht implementiert.
352
353     # my @filenames = DATEV->obe_export(\%myconfig, \%$form);
354     # if (@filenames) {
355     #   print(qq|<br><b>| . $locale->text('OBE-Export erfolgreich!') . qq|</b><br>|);
356     #   $link .= "&filenames=" . $form->escape(join(":", @filenames));
357     #   print(qq|<br><a href="$link">Download</a>|);
358     # } else {
359     #   $form->error("OBE-Export schlug fehl.");
360     # }
361   }
362
363   print("</body></html>");
364
365   $lxdebug->leave_sub();
366 }
367
368 sub download {
369   $lxdebug->enter_sub();
370
371   $auth->assert('datev_export');
372
373   my $tmp_name = Common->tmpname();
374   my $zip_name = strftime("lx-office-datev-export-%Y%m%d.zip", localtime(time()));
375
376   my $cwd = getcwd();
377
378   my $path = DATEV::get_path_for_download_token($form->{download_token});
379   if (!$path) {
380     $form->error($locale->text("Your download does not exist anymore. Please re-run the DATEV export assistant."));
381   }
382
383   chdir($path) || die("chdir $path");
384
385   my @filenames = glob "*";
386
387   if (!@filenames) {
388     chdir($cwd);
389     DATEV::clean_temporary_directories();
390     $form->error($locale->text("Your download does not exist anymore. Please re-run the DATEV export assistant."));
391   }
392
393   my $zip = Archive::Zip->new();
394   map { $zip->addFile($_); } @filenames;
395   $zip->writeToFileNamed($tmp_name);
396
397   chdir($cwd);
398
399   open(IN, $tmp_name) || die("open $tmp_name");
400   print("Content-Type: application/zip\n");
401   print("Content-Disposition: attachment; filename=\"${zip_name}\"\n\n");
402   while (<IN>) {
403     print($_);
404   }
405   close(IN);
406
407   unlink($tmp_name);
408
409   DATEV::clean_temporary_directories();
410
411   $lxdebug->leave_sub();
412 }