Webbserverprogrammering 1

Show sourcecode

The following files exists in this folder. Click to view.

Webserver1/Ovningar/Slutprojekt/vendor/vlucas/phpdotenv/src/Repository/Adapter/

AdapterInterface.php
ApacheAdapter.php
ArrayAdapter.php
EnvConstAdapter.php
GuardedWriter.php
ImmutableWriter.php
MultiReader.php
MultiWriter.php
PutenvAdapter.php
ReaderInterface.php
ReplacingWriter.php
ServerConstAdapter.php
WriterInterface.php

PutenvAdapter.php

92 lines ASCII Unix (LF)
<?php

declare(strict_types=1);

namespace 
Dotenv\Repository\Adapter;

use 
PhpOption\None;
use 
PhpOption\Option;
use 
PhpOption\Some;

final class 
PutenvAdapter implements AdapterInterface
{
    
/**
     * Create a new putenv adapter instance.
     *
     * @return void
     */
    
private function __construct()
    {
        
//
    
}

    
/**
     * Create a new instance of the adapter, if it is available.
     *
     * @return \PhpOption\Option<\Dotenv\Repository\Adapter\AdapterInterface>
     */
    
public static function create()
    {
        if (
self::isSupported()) {
            
/** @var \PhpOption\Option<AdapterInterface> */
            
return Some::create(new self());
        }

        return 
None::create();
    }

    
/**
     * Determines if the adapter is supported.
     *
     * @return bool
     */
    
private static function isSupported()
    {
        return \
function_exists('getenv') && \function_exists('putenv');
    }

    
/**
     * Read an environment variable, if it exists.
     *
     * @param non-empty-string $name
     *
     * @return \PhpOption\Option<string>
     */
    
public function read(string $name)
    {
        
/** @var \PhpOption\Option<string> */
        
return Option::fromValue(\getenv($name), false)->filter(static function ($value) {
            return \
is_string($value);
        });
    }

    
/**
     * Write to an environment variable, if possible.
     *
     * @param non-empty-string $name
     * @param string           $value
     *
     * @return bool
     */
    
public function write(string $namestring $value)
    {
        \
putenv("$name=$value");

        return 
true;
    }

    
/**
     * Delete an environment variable, if possible.
     *
     * @param non-empty-string $name
     *
     * @return bool
     */
    
public function delete(string $name)
    {
        \
putenv($name);

        return 
true;
    }
}