add rfid check to card package import

This commit is contained in:
Roland Schneider 2016-07-30 20:08:42 +02:00
parent 167d614927
commit d6c570a31b

View File

@ -21,7 +21,8 @@ use common\components\Upload;
/** /**
* CardPackageController implements the CRUD actions for CardPackage model. * CardPackageController implements the CRUD actions for CardPackage model.
*/ */
class CardPackageController extends \backend\controllers\BackendController { class CardPackageController extends \backend\controllers\BackendController
{
public function behaviors() public function behaviors()
@ -32,28 +33,30 @@ class CardPackageController extends \backend\controllers\BackendController {
'rules' => [ 'rules' => [
// allow authenticated users // allow authenticated users
[ [
'actions' => ['create','index','view','import','download'], 'actions' => ['create', 'index', 'view', 'import', 'download'],
'allow' => true, 'allow' => true,
'roles' => ['admin','employee','reception'], 'roles' => ['admin', 'employee', 'reception'],
], ],
// everything else is denied // everything else is denied
], ],
], ],
]; ];
} }
/** /**
* Lists all CardPackage models. * Lists all CardPackage models.
* *
* @return mixed * @return mixed
*/ */
public function actionIndex() { public function actionIndex()
{
$searchModel = new CardPackageSearch (); $searchModel = new CardPackageSearch ();
$dataProvider = $searchModel->search ( Yii::$app->request->queryParams ); $dataProvider = $searchModel->search(Yii::$app->request->queryParams);
return $this->render ( 'index', [ return $this->render('index', [
'searchModel' => $searchModel, 'searchModel' => $searchModel,
'dataProvider' => $dataProvider 'dataProvider' => $dataProvider
] ); ]);
} }
/** /**
@ -62,45 +65,48 @@ class CardPackageController extends \backend\controllers\BackendController {
* @param integer $id * @param integer $id
* @return mixed * @return mixed
*/ */
public function actionView($id) { public function actionView($id)
$model = $this->findModel ( $id ); {
$model = $this->findModel($id);
$query = Card::find (); $query = Card::find();
$query->innerJoin ( "card_card_package_assignment", "card_card_package_assignment.id_card = card.id_card " ); $query->innerJoin("card_card_package_assignment", "card_card_package_assignment.id_card = card.id_card ");
$query->andWhere ( [ $query->andWhere([
'card_card_package_assignment.id_card_package' => $id 'card_card_package_assignment.id_card_package' => $id
] ); ]);
$dataProvider = new ActiveDataProvider ( [ $dataProvider = new ActiveDataProvider ([
'query' => $query 'query' => $query
] ); ]);
return $this->render ( 'view', [ return $this->render('view', [
'model' => $model, 'model' => $model,
'dataProvider' => $dataProvider 'dataProvider' => $dataProvider
] ); ]);
} }
public function actionDownload($id) {
$model = $this->findModel ( $id );
$model->updateCounters ( [ public function actionDownload($id)
{
$model = $this->findModel($id);
$model->updateCounters([
'printed' => 1 'printed' => 1
] ); ]);
$query = Card::find (); $query = Card::find();
$query->innerJoin ( "card_card_package_assignment", "card_card_package_assignment.id_card = card.id_card " ); $query->innerJoin("card_card_package_assignment", "card_card_package_assignment.id_card = card.id_card ");
$query->andWhere ( [ $query->andWhere([
'card_card_package_assignment.id_card_package' => $id 'card_card_package_assignment.id_card_package' => $id
] ); ]);
$cards = $query->all (); $cards = $query->all();
$numbers = [ ]; $numbers = [];
foreach ( $cards as $card ) { foreach ($cards as $card) {
$numbers [] = $card->number; $numbers [] = $card->number;
} }
$this->generateXLS ( $model, $numbers ); $this->generateXLS($model, $numbers);
} }
/** /**
@ -109,64 +115,67 @@ class CardPackageController extends \backend\controllers\BackendController {
* *
* @return mixed * @return mixed
*/ */
public function actionCreate() { public function actionCreate()
{
$model = new CardPackage (); $model = new CardPackage ();
$model->id_user = \Yii::$app->user->id; $model->id_user = \Yii::$app->user->id;
$model->printed = 0; $model->printed = 0;
if ($model->load ( Yii::$app->request->post () ) && $model->validate ()) { if ($model->load(Yii::$app->request->post()) && $model->validate()) {
$conn = \Yii::$app->db; $conn = \Yii::$app->db;
$tx = $conn->beginTransaction (); $tx = $conn->beginTransaction();
$model->save ( false ); $model->save(false);
$count = $model->count; $count = $model->count;
$numGen = new FreeUniqueCardNumberGenerator ( [ $numGen = new FreeUniqueCardNumberGenerator ([
'count' => $model->count, 'count' => $model->count,
'prefix' => '10' 'prefix' => '10'
] ); ]);
$numGen->generate (); $numGen->generate();
$numbers = $numGen->cache; $numbers = $numGen->cache;
try { try {
foreach ( $numbers as $number ) { foreach ($numbers as $number) {
$card = new Card (); $card = new Card ();
$card->number = $number; $card->number = $number;
$card->type = Card::TYPE_RFID; $card->type = Card::TYPE_RFID;
$card->status = Card::STATUS_ACTIVE; $card->status = Card::STATUS_ACTIVE;
$card->save ( false ); $card->save(false);
$cardAssignment = new CardCardPackageAssignment (); $cardAssignment = new CardCardPackageAssignment ();
$cardAssignment->id_card = $card->id_card; $cardAssignment->id_card = $card->id_card;
$cardAssignment->id_card_package = $model->id_card_package; $cardAssignment->id_card_package = $model->id_card_package;
$cardAssignment->save ( false ); $cardAssignment->save(false);
} }
$tx->commit (); $tx->commit();
return $this->redirect ( [ return $this->redirect([
'index' 'index'
] ); ]);
} catch ( \Exception $e ) { } catch (\Exception $e) {
$tx->rollBack (); $tx->rollBack();
} }
return $this->render ( 'create', [ return $this->render('create', [
'model' => $model 'model' => $model
] ); ]);
} else { } else {
return $this->render ( 'create', [ return $this->render('create', [
'model' => $model 'model' => $model
] ); ]);
} }
} }
protected function generateXLS($model, $numbers) {
protected function generateXLS($model, $numbers)
{
$objPHPExcel = new \PHPExcel (); $objPHPExcel = new \PHPExcel ();
$sheet = $objPHPExcel->setActiveSheetIndex ( 0 ); $sheet = $objPHPExcel->setActiveSheetIndex(0);
// $row = 1; // $row = 1;
// $sheet->setCellValue('A'.$row, "Termék név") // $sheet->setCellValue('A'.$row, "Termék név")
@ -176,48 +185,49 @@ class CardPackageController extends \backend\controllers\BackendController {
// ->setCellValue('E'.$row, "Eladás összege"); // ->setCellValue('E'.$row, "Eladás összege");
$row = 0; $row = 0;
foreach ( $numbers as $number ) { foreach ($numbers as $number) {
$row ++; $row++;
$sheet->setCellValue ( 'A' . $row, $number ); $sheet->setCellValue('A' . $row, $number);
} }
$fileName = "kartya_csomag"; $fileName = "kartya_csomag";
$fileName .= "_" . $model->id_card_package; $fileName .= "_" . $model->id_card_package;
$fileName .= "_" . date ( "Ymd_His" ); $fileName .= "_" . date("Ymd_His");
$fileName .= ".xls"; $fileName .= ".xls";
// Redirect output to a clients web browser (Excel5) // Redirect output to a clients web browser (Excel5)
header ( 'Content-Type: application/vnd.ms-excel' ); header('Content-Type: application/vnd.ms-excel');
header ( 'Content-Disposition: attachment;filename="' . $fileName . '"' ); header('Content-Disposition: attachment;filename="' . $fileName . '"');
header ( 'Cache-Control: max-age=0' ); header('Cache-Control: max-age=0');
// If you're serving to IE 9, then the following may be needed // If you're serving to IE 9, then the following may be needed
header ( 'Cache-Control: max-age=1' ); header('Cache-Control: max-age=1');
// If you're serving to IE over SSL, then the following may be needed // If you're serving to IE over SSL, then the following may be needed
header ( 'Expires: Mon, 26 Jul 1997 05:00:00 GMT' ); // Date in the past header('Expires: Mon, 26 Jul 1997 05:00:00 GMT'); // Date in the past
header ( 'Last-Modified: ' . gmdate ( 'D, d M Y H:i:s' ) . ' GMT' ); // always modified header('Last-Modified: ' . gmdate('D, d M Y H:i:s') . ' GMT'); // always modified
header ( 'Cache-Control: cache, must-revalidate' ); // HTTP/1.1 header('Cache-Control: cache, must-revalidate'); // HTTP/1.1
header ( 'Pragma: public' ); // HTTP/1.0 header('Pragma: public'); // HTTP/1.0
$objWriter = \PHPExcel_IOFactory::createWriter ( $objPHPExcel, 'Excel5' ); $objWriter = \PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');
$objWriter->save ( 'php://output' ); $objWriter->save('php://output');
exit (); exit ();
} }
public function actionImport() {
public function actionImport()
{
$model = new CardPackageImportForm (); $model = new CardPackageImportForm ();
if (Yii::$app->request->isPost) { if (Yii::$app->request->isPost) {
$model->file = UploadedFile::getInstance ( $model, 'file' ); $model->file = UploadedFile::getInstance($model, 'file');
if ($model->validate()) {
if ($model->validate ()) {
// print_r($model->file); // print_r($model->file);
// $model->message = "ok"; // $model->message = "ok";
$file = $model->file->tempName; $file = $model->file->tempName;
$xlsUtil = new XLSUtil (); $xlsUtil = new XLSUtil ();
$xlsUtil->loadFromFileName ( $file ); $xlsUtil->loadFromFileName($file);
$array = $xlsUtil->toArray (); $array = $xlsUtil->toArray();
// print_r($array); // print_r($array);
// print_r( array_column($array, 2)); // print_r( array_column($array, 2));
@ -226,44 +236,55 @@ class CardPackageController extends \backend\controllers\BackendController {
// echo $item[2]; // echo $item[2];
// } // }
foreach ( $array as $row ) { foreach ($array as $row) {
try { try {
$tx = \Yii::$app->db->beginTransaction (); $tx = \Yii::$app->db->beginTransaction();
$card = Card::find ()->andWhere ( [ $rfidIsValid = false;
$rfid = $row[2];
if (isset($rfid) && !empty($rfid) && strlen($rfid) > 8) {
$rfidIsValid = true;
}
if ( !$rfidIsValid ){
throw new \Exception("Rfid is invalid");
}
$card = Card::find()->andWhere([
'number' => $row [0] 'number' => $row [0]
] )->one (); ])->one();
if ( isset( $card )) { if (isset($card)) {
$card->rfid_key = Helper::fixAsciiChars( $row [2 ] ); $card->rfid_key = Helper::fixAsciiChars($row [2]);
$card->save(false); $card->save(false);
}else{ } else {
throw new \Exception("Card not found"); throw new \Exception("Card not found");
} }
$tx->commit();
$tx->commit ();
$model->done = $model->done + 1; $model->done = $model->done + 1;
} catch ( \Exception $e ) {
$tx->rollBack (); } catch (\Exception $e) {
$tx->rollBack();
$model->failed = $model->failed + 1; $model->failed = $model->failed + 1;
\Yii::error ( "Failed to import card rfid: " . print_r ( $row, true ) ); \Yii::error("Failed to import card rfid: " . print_r($row, true));
} }
} }
\Yii::$app->session->setFlash ( 'success', "Az importálás eredménye: sikeres:" . $model->done . "; Sikertelen: " . $model->failed ); \Yii::$app->session->setFlash('success', "Az importálás eredménye: sikeres:" . $model->done . "; Sikertelen: " . $model->failed);
\Yii::info('Importálás: sikeres: ' .$model->done . " , sikertelen: " . $model->failed); \Yii::info('Importálás: sikeres: ' . $model->done . " , sikertelen: " . $model->failed);
return $this->redirect ( [ return $this->redirect([
'card-package/import' 'card-package/import'
] ); ]);
} }
} }
return $this->render ( "import", [ return $this->render("import", [
'model' => $model 'model' => $model
] ); ]);
} }
/** /**
@ -273,18 +294,19 @@ class CardPackageController extends \backend\controllers\BackendController {
* @param integer $id * @param integer $id
* @return mixed * @return mixed
*/ */
public function actionUpdate($id) { public function actionUpdate($id)
$model = $this->findModel ( $id ); {
$model = $this->findModel($id);
if ($model->load ( Yii::$app->request->post () ) && $model->save ()) { if ($model->load(Yii::$app->request->post()) && $model->save()) {
return $this->redirect ( [ return $this->redirect([
'view', 'view',
'id' => $model->id_card_package 'id' => $model->id_card_package
] ); ]);
} else { } else {
return $this->render ( 'update', [ return $this->render('update', [
'model' => $model 'model' => $model
] ); ]);
} }
} }
@ -295,12 +317,13 @@ class CardPackageController extends \backend\controllers\BackendController {
* @param integer $id * @param integer $id
* @return mixed * @return mixed
*/ */
public function actionDelete($id) { public function actionDelete($id)
$this->findModel ( $id )->delete (); {
$this->findModel($id)->delete();
return $this->redirect ( [ return $this->redirect([
'index' 'index'
] ); ]);
} }
/** /**
@ -311,11 +334,12 @@ class CardPackageController extends \backend\controllers\BackendController {
* @return CardPackage the loaded model * @return CardPackage the loaded model
* @throws NotFoundHttpException if the model cannot be found * @throws NotFoundHttpException if the model cannot be found
*/ */
protected function findModel($id) { protected function findModel($id)
if (($model = CardPackage::findOne ( $id )) !== null) { {
if (($model = CardPackage::findOne($id)) !== null) {
return $model; return $model;
} else { } else {
throw new NotFoundHttpException ( 'The requested page does not exist.' ); throw new NotFoundHttpException ('The requested page does not exist.');
} }
} }
} }