File size: 3,542 Bytes
105b369
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
from typing import Optional, Dict

from phi.app.db_app import DbApp
from phi.docker.app.base import DockerApp, ContainerContext  # noqa: F401


class MySQLDb(DockerApp, DbApp):
    # -*- App Name
    name: str = "mysql"

    # -*- Image Configuration
    image_name: str = "mysql"
    image_tag: str = "8.0.33"

    # -*- App Ports
    # Open a container port if open_port=True
    open_port: bool = True
    port_number: int = 3306

    # -*- MySQL Configuration
    # Provide MYSQL_USER as mysql_user or MYSQL_USER in secrets_file
    mysql_user: Optional[str] = None
    # Provide MYSQL_PASSWORD as mysql_password or MYSQL_PASSWORD in secrets_file
    mysql_password: Optional[str] = None
    # Provide MYSQL_ROOT_PASSWORD as root_password or MYSQL_ROOT_PASSWORD in secrets_file
    root_password: Optional[str] = None
    # Provide MYSQL_DATABASE as mysql_database or MYSQL_DATABASE in secrets_file
    mysql_database: Optional[str] = None
    db_driver: str = "mysql"

    # -*- MySQL Volume
    # Create a volume for mysql storage
    create_volume: bool = True
    # Path to mount the volume inside the container
    volume_container_path: str = "/var/lib/mysql"

    def get_db_user(self) -> Optional[str]:
        return self.mysql_user or self.get_secret_from_file("MYSQL_USER")

    def get_db_password(self) -> Optional[str]:
        return self.mysql_password or self.get_secret_from_file("MYSQL_PASSWORD")

    def get_db_database(self) -> Optional[str]:
        return self.mysql_database or self.get_secret_from_file("MYSQL_DATABASE")

    def get_db_driver(self) -> Optional[str]:
        return self.db_driver

    def get_db_host(self) -> Optional[str]:
        return self.get_container_name()

    def get_db_port(self) -> Optional[int]:
        return self.container_port

    def get_container_env(self, container_context: ContainerContext) -> Dict[str, str]:
        # Container Environment
        container_env: Dict[str, str] = self.container_env or {}

        # Set mysql env vars
        # Check: https://hub.docker.com/_/mysql
        db_user = self.get_db_user()
        if db_user is not None and db_user != "root":
            container_env["MYSQL_USER"] = db_user
            db_password = self.get_db_password()
            if db_password is not None:
                container_env["MYSQL_PASSWORD"] = db_password
        db_database = self.get_db_database()
        if db_database is not None:
            container_env["MYSQL_DATABASE"] = db_database
        if self.root_password is not None:
            container_env["MYSQL_ROOT_PASSWORD"] = self.root_password

        # Set aws region and profile
        self.set_aws_env_vars(env_dict=container_env)

        # Update the container env using env_file
        env_data_from_file = self.get_env_file_data()
        if env_data_from_file is not None:
            container_env.update({k: str(v) for k, v in env_data_from_file.items() if v is not None})

        # Update the container env using secrets_file
        secret_data_from_file = self.get_secret_file_data()
        if secret_data_from_file is not None:
            container_env.update({k: str(v) for k, v in secret_data_from_file.items() if v is not None})

        # Update the container env with user provided env_vars
        # this overwrites any existing variables with the same key
        if self.env_vars is not None and isinstance(self.env_vars, dict):
            container_env.update({k: str(v) for k, v in self.env_vars.items() if v is not None})

        return container_env