Ejemplo n.º 1
0
 public function actionBeaconData($beacons)
 {
     $return = [];
     if ($beacons = json_decode($beacons, true)) {
         foreach ($beacons as $beacon) {
             if (isset($beacon['uuid']) && isset($beacon['minor']) && isset($beacon['major'])) {
                 $beacon = Beacons::find()->filterWhere(['uuid' => $beacon['uuid'], 'minor' => $beacon['minor'], 'major' => $beacon['major']])->one();
                 if ($beacon instanceof Beacons) {
                     $beacon_statistic = new ClientBeacons();
                     $beacon_statistic->beacon_id = $beacon->id;
                     if ($this->client_user instanceof ClientUsers) {
                         $beacon_statistic->client_id = $this->client_user->id;
                     }
                     $beacon_statistic->save();
                     $beacon = $beacon->toArray();
                     $beacon['status'] = self::OK;
                 } else {
                     $beacon = ['status' => self::NOT_FOUND];
                 }
                 $return[] = $beacon;
             } else {
                 $return[] = ['status' => self::INVALID_REQUEST_DATA];
             }
         }
         return $return;
     } else {
         throw new HttpException(400, 'Invalid data');
     }
 }
Ejemplo n.º 2
0
 public function clientBeacons($client_user_id = null)
 {
     $query = Beacons::find();
     $dataProvider = new ActiveDataProvider(['query' => $query]);
     if (!$this->validate()) {
         // uncomment the following line if you do not want to any records when validation fails
         // $query->where('0=1');
         return $dataProvider;
     }
     if ($client_user_id !== null) {
         $user = ClientUsers::findOne(['id' => $client_user_id]);
         $query->joinWith(['clientBeacons' => function (ActiveQuery $query) use($user) {
             $query->andFilterWhere(['client_id' => $user->id]);
         }]);
     }
     $query->andFilterWhere(['id' => $this->id, 'minor' => $this->minor, 'major' => $this->major]);
     $query->andFilterWhere(['like', 'title', $this->title])->andFilterWhere(['like', 'description', $this->description])->andFilterWhere(['like', 'uuid', $this->uuid]);
     return $dataProvider;
 }
Ejemplo n.º 3
0
 public function getBeaconsQuery($query = null)
 {
     if ($query == null) {
         $query = Beacons::find();
     }
     $user = $this;
     $query->joinWith(['groups' => function (ActiveQuery $query) use($user) {
         $query->joinWith(['users' => function (ActiveQuery $query) use($user) {
             $query->andFilterWhere(['users.id' => $user->id]);
         }]);
     }]);
     return $query;
 }