]> git.mxchange.org Git - shipsimu.git/blobdiff - application/ship-simu/main/wrapper/class_CompanyDatabaseWrapper.php
More stubs added, code "made" generic:
[shipsimu.git] / application / ship-simu / main / wrapper / class_CompanyDatabaseWrapper.php
index d403d18b8530d0646719b9a5f2e1d318a2895184..b49b1d050c4a56c4038baac528721ec8d7127803 100644 (file)
@@ -23,7 +23,8 @@
  */
 class CompanyDatabaseWrapper extends BaseDatabaseWrapper {
        // Constants for database tables
-       const DB_TABLE_COMPANY = "company";
+       const DB_TABLE_COMPANY_DATA = "company";
+       const DB_TABLE_COMPANY_USER = "company_user";
 
        /**
         * Protected constructor
@@ -51,11 +52,47 @@ class CompanyDatabaseWrapper extends BaseDatabaseWrapper {
                $wrapperInstance = new CompanyDatabaseWrapper();
 
                // Set (primary!) table name
-               $wrapperInstance->setTableName(self::DB_TABLE_COMPANY);
+               $wrapperInstance->setTableName(self::DB_TABLE_COMPANY_DATA);
 
                // Return the instance
                return $wrapperInstance;
        }
+
+       /**
+        * Checks wether the given user participates in a company
+        *
+        * @param       $userInstance   An instance of a user class
+        * @return      $participates   Wether the user participates at lease in one company
+        */
+       public function ifUserParticipatesInCompany (BaseUser $userInstance)  {
+               // By default no user owns any company... ;)
+               $participates = false;
+
+               // Get a search criteria class
+               $criteriaInstance = ObjectFactory::createObjectByConfiguredName('search_criteria_class');
+
+               // Add the user primary key as a search criteria
+               $criteriaInstance->addCriteria('participant_id', $userInstance->getPrimaryKey());
+               $criteriaInstance->setLimit(1);
+
+               // Set company->user table
+               $this->setTableName(self::DB_TABLE_COMPANY_USER);
+
+               // Get the result back
+               $resultInstance = $this->doSelectByCriteria($criteriaInstance);
+
+               // Is there a result?
+               if ($resultInstance->next()) {
+                       // Then cache it
+                       $this->setResultInstance($resultInstance);
+
+                       // Entry found for further analysis/processing
+                       $participates = true;
+               } // END - if
+
+               // Return the result
+               return $participates;
+       }
 }
 
 // [EOF]