ReportController.php
3.88 KB
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
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
<?php
#error_reporting(E_ALL);
#ini_set("display_errors", 1);
/**
* i-Educar - Sistema de gestão escolar
*
* Copyright (C) 2006 Prefeitura Municipal de Itajaí
* <ctima@itajai.sc.gov.br>
*
* Este programa é software livre; você pode redistribuí-lo e/ou modificá-lo
* sob os termos da Licença Pública Geral GNU conforme publicada pela Free
* Software Foundation; tanto a versão 2 da Licença, como (a seu critério)
* qualquer versão posterior.
*
* Este programa é distribuído na expectativa de que seja útil, porém, SEM
* NENHUMA GARANTIA; nem mesmo a garantia implícita de COMERCIABILIDADE OU
* ADEQUAÇÃO A UMA FINALIDADE ESPECÍFICA. Consulte a Licença Pública Geral
* do GNU para mais detalhes.
*
* Você deve ter recebido uma cópia da Licença Pública Geral do GNU junto
* com este programa; se não, escreva para a Free Software Foundation, Inc., no
* endereço 59 Temple Street, Suite 330, Boston, MA 02111-1307 USA.
*
* @author Lucas D'Avila <lucasdavila@portabilis.com.br>
* @category i-Educar
* @license @@license@@
* @package Api
* @subpackage Modules
* @since Arquivo disponível desde a versão ?
* @version $Id$
*/
require_once 'lib/Portabilis/Controller/ApiCoreController.php';
require_once "Reports/Reports/BoletimReport.php";
class ReportController extends ApiCoreController
{
// validations
protected function canGetBoletim() {
return $this->validatesId('escola') &&
$this->validatesId('matricula');
}
// load
protected function loadDadosForMatricula($matriculaId){
$sql = "select cod_matricula as id, ref_cod_aluno as aluno_id, matricula.ano,
escola.ref_cod_instituicao as instituicao_id, matricula.ref_ref_cod_escola
as escola_id, matricula.ref_cod_curso as curso_id, matricula.ref_ref_cod_serie
as serie_id, matricula_turma.ref_cod_turma as turma_id from
pmieducar.matricula_turma, pmieducar.matricula, pmieducar.escola where escola.cod_escola =
matricula.ref_ref_cod_escola and ref_cod_matricula = cod_matricula and ref_cod_matricula =
$1 and matricula.ativo = matricula_turma.ativo and matricula_turma.ativo = 1 order by
matricula_turma.sequencial limit 1";
$dadosMatricula = $this->fetchPreparedQuery($sql, $matriculaId, false, 'first-row');
$attrs = array('id', 'aluno_id', 'ano', 'instituicao_id', 'escola_id',
'curso_id', 'serie_id', 'turma_id');
return Portabilis_Array_Utils::filter($dadosMatricula, $attrs);
}
// api
protected function getBoletim() {
if ($this->canGetBoletim()) {
$dadosMatricula = $this->loadDadosForMatricula($this->getRequest()->matricula_id);
$boletimReport = new BoletimReport();
$boletimReport->addArg('matricula', (int)$dadosMatricula['id']);
$boletimReport->addArg('ano', (int)$dadosMatricula['ano']);
$boletimReport->addArg('instituicao', (int)$dadosMatricula['instituicao_id']);
$boletimReport->addArg('escola', (int)$dadosMatricula['escola_id']);
$boletimReport->addArg('curso', (int)$dadosMatricula['curso_id']);
$boletimReport->addArg('serie', (int)$dadosMatricula['serie_id']);
$boletimReport->addArg('turma', (int)$dadosMatricula['turma_id']);
$encoding = 'base64';
$dumpsOptions = array('options' => array('encoding' => $encoding));
$encoded = $boletimReport->dumps($dumpsOptions);
return array('matricula_id' => $this->getRequest()->matricula_id,
'encoding' => $encoding,
'encoded' => $encoded);
}
}
public function Gerar() {
if ($this->isRequestFor('get', 'boletim'))
$this->appendResponse($this->getBoletim());
else
$this->notImplementedOperationError();
}
}