/** * Initializes the available application contexts and returns them. * * @param \AppserverIo\Appserver\Core\Interfaces\ContainerInterface $container The container we want to add the applications to * * @return array The array with the application contexts */ public function loadContextInstancesByWorkingDir(ContainerInterface $container) { // initialize the array for the context instances $contextInstances = array(); // attach the context to the context instances $context = $this->loadContextInstance($container->getContainerNode(), getcwd()); $contextInstances[$context->getName()] = $context; // return the array with the context instances return $contextInstances; }
/** * Initializes the available application contexts and returns them. * * @param \AppserverIo\Appserver\Core\Interfaces\ContainerInterface $container The container we want to add the applications to * * @return array The array with the application contexts */ public function loadContextInstancesByContainer(ContainerInterface $container) { try { // initialize the array for the context instances $contextInstances = array(); // validate the base context file /** @var AppserverIo\Appserver\Core\Api\ConfigurationService $configurationService */ $configurationService = $this->newService('AppserverIo\\Appserver\\Core\\Api\\ConfigurationService'); $configurationService->validateFile($baseContextPath = $this->getConfdDir('context.xml'), null); //load it as default if validation succeeds $baseContext = new ContextNode(); $baseContext->initFromFile($baseContextPath); } catch (ConfigurationException $ce) { // load the logger and log the XML validation errors $systemLogger = $this->getInitialContext()->getSystemLogger(); $systemLogger->error($ce->__toString()); // additionally log a message that DS will be missing $systemLogger->critical(sprintf('Problems validating base context file %s, this might affect app configurations badly.', $baseContextPath)); } // iterate over all applications and create the context configuration foreach (glob($container->getAppBase() . '/*', GLOB_ONLYDIR) as $webappPath) { // prepare the context path $contextPath = basename($webappPath); // start with a fresh clone of the base context configuration $context = clone $baseContext; // try to load a context configuration (from appserver.xml) for the context path if ($contextToMerge = $container->getContainerNode()->getHost()->getContext($contextPath)) { $context->merge($contextToMerge); } // iterate through all context configurations (context.xml), validate and merge them foreach ($this->globDir($webappPath . '/META-INF/context.xml') as $contextFile) { try { // validate the application specific context $configurationService->validateFile($contextFile, null); // create a new context node instance $contextInstance = new ContextNode(); $contextInstance->initFromFile($contextFile); // merge it into the default configuration $context->merge($contextInstance); } catch (ConfigurationException $ce) { // load the logger and log the XML validation errors $systemLogger = $this->getInitialContext()->getSystemLogger(); $systemLogger->error($ce->__toString()); // additionally log a message that DS will be missing $systemLogger->critical(sprintf('Will skip app specific context file %s, configuration might be faulty.', $contextFile)); } } // set the real context name $context->setName($contextPath); // attach the context to the context instance $contextInstances[$contextPath] = $context; } // return the array with the context instances return $contextInstances; }
/** * Initializes the available application contexts and returns them. * * @param \AppserverIo\Appserver\Core\Interfaces\ContainerInterface $container The container we want to add the applications to * * @return ContextNode[] The array with the application contexts */ public function loadContextInstancesByContainer(ContainerInterface $container) { // initialize the array for the context instances $contextInstances = array(); // iterate over all applications and create the context configuration foreach (glob($container->getAppBase() . '/*', GLOB_ONLYDIR) as $webappPath) { $context = $this->loadContextInstance($container->getContainerNode(), $webappPath); $contextInstances[$context->getName()] = $context; } // return the array with the context instances return $contextInstances; }
/** * Prepares the application with the specific data found in the * passed context node. * * @param \AppserverIo\Appserver\Core\Interfaces\ContainerInterface $container The container instance bind the application to * @param \AppserverIo\Appserver\Core\Api\Node\ContextNode $context The application configuration * * @return void */ public function prepare(ContainerInterface $container, ContextNode $context) { // load the unique application name + the naming directory $uniqueName = $this->getUniqueName(); $namingDirectory = $this->getNamingDirectory(); // create subdirectories for the application and the logger $namingDirectory->createSubdirectory(sprintf('php:global/%s', $uniqueName)); $namingDirectory->createSubdirectory(sprintf('php:global/log/%s', $uniqueName)); // create the applications 'env' + 'env/persistence' directory the beans + persistence units will be bound to $namingDirectory->createSubdirectory(sprintf('php:env/%s', $uniqueName)); $namingDirectory->createSubdirectory(sprintf('php:global/%s/env', $uniqueName)); $namingDirectory->createSubdirectory(sprintf('php:global/%s/env/persistence', $uniqueName)); // bind the directory containing the applications $namingDirectory->bind(sprintf('php:env/%s/appBase', $uniqueName), $container->getAppBase()); // prepare the application specific directories $webappPath = sprintf('%s/%s', $this->getAppBase(), $this->getName()); $tmpDirectory = sprintf('%s/%s', $container->getTmpDir(), $this->getName()); $cacheDirectory = sprintf('%s/%s', $tmpDirectory, ltrim($context->getParam(DirectoryKeys::CACHE), '/')); $sessionDirectory = sprintf('%s/%s', $tmpDirectory, ltrim($context->getParam(DirectoryKeys::SESSION), '/')); // prepare the application specific environment variables $namingDirectory->bind(sprintf('php:env/%s/webappPath', $uniqueName), $webappPath); $namingDirectory->bind(sprintf('php:env/%s/tmpDirectory', $uniqueName), $tmpDirectory); $namingDirectory->bind(sprintf('php:env/%s/cacheDirectory', $uniqueName), $cacheDirectory); $namingDirectory->bind(sprintf('php:env/%s/sessionDirectory', $uniqueName), $sessionDirectory); // bind the interface as reference to the application $namingDirectory->bind(sprintf('php:global/%s/env/ApplicationInterface', $uniqueName), $this); }
/** * Visitor method that registers the application in the container. * * @param \AppserverIo\Appserver\Core\Interfaces\ContainerInterface $container The container instance bind the application to * @param \AppserverIo\Appserver\Core\Api\Node\ContextNode $context The application configuration * * @return void */ public static function visit(ContainerInterface $container, ContextNode $context) { // prepare the path to the applications base directory $folder = $container->getAppBase() . DIRECTORY_SEPARATOR . $context->getName(); // declare META-INF and WEB-INF directory $webInfDir = $folder . DIRECTORY_SEPARATOR . 'WEB-INF'; $metaInfDir = $folder . DIRECTORY_SEPARATOR . 'META-INF'; // check if we've a directory containing a valid application, // at least a WEB-INF or META-INF folder has to be available if (!is_dir($webInfDir) && !is_dir($metaInfDir)) { return; } // load the naming directory + initial context $initialContext = $container->getInitialContext(); $namingDirectory = $container->getNamingDirectory(); // load the application service $appService = $container->newService('AppserverIo\\Appserver\\Core\\Api\\AppService'); // load the application type $contextType = $context->getType(); $applicationName = $context->getName(); // create a new application instance /** @var \AppserverIo\Appserver\Application\Application $application */ $application = new $contextType(); // initialize the storage for managers, virtual hosts an class loaders $managers = new GenericStackable(); $provisioners = new GenericStackable(); $classLoaders = new GenericStackable(); // initialize the generic instances and information $application->injectManagers($managers); $application->injectName($applicationName); $application->injectProvisioners($provisioners); $application->injectClassLoaders($classLoaders); $application->injectInitialContext($initialContext); $application->injectNamingDirectory($namingDirectory); // prepare the application instance $application->prepare($context); // create the applications temporary folders and cleans the folders up /** @var \AppserverIo\Appserver\Core\Api\AppService $appService */ PermissionHelper::sudo(array($appService, 'createTmpFolders'), array($application)); $appService->cleanUpFolders($application); // add the configured class loaders /** @var \AppserverIo\Appserver\Core\Api\Node\ClassLoaderNode $classLoader */ foreach ($context->getClassLoaders() as $classLoader) { /** @var \AppserverIo\Appserver\Core\Interfaces\ClassLoaderFactoryInterface $classLoaderFactory */ if ($classLoaderFactory = $classLoader->getFactory()) { // use the factory if available $classLoaderFactory::visit($application, $classLoader); } else { // if not, try to instanciate the class loader directly $classLoaderType = $classLoader->getType(); $application->addClassLoader(new $classLoaderType($classLoader), $classLoader); } } // add the configured managers /** @var \AppserverIo\Appserver\Core\Api\Node\ManagerNode $manager */ foreach ($context->getManagers() as $manager) { if ($managerFactory = $manager->getFactory()) { // use the factory if available $managerFactory::visit($application, $manager); } else { // if not, try to instanciate the manager directly $managerType = $manager->getType(); $application->addManager(new $managerType($manager), $manager); } } // add the configured provisioners /** @var \AppserverIo\Appserver\Core\Api\Node\ProvisionerNode $provisioner */ foreach ($context->getProvisioners() as $provisioner) { if ($provisionerFactory = $provisioner->getFactory()) { // use the factory if available $provisionerFactory::visit($application, $provisioner); } else { // if not, try to instanciate the provisioner directly $provisionerType = $provisioner->getType(); $application->addProvisioner(new $provisionerType($provisioner), $provisioner); } } // add the application to the container $container->addApplication($application); }