diff --git a/docker-jans-persistence-loader/Dockerfile b/docker-jans-persistence-loader/Dockerfile index 2327a9cf9a5..bb662da7577 100644 --- a/docker-jans-persistence-loader/Dockerfile +++ b/docker-jans-persistence-loader/Dockerfile @@ -23,7 +23,8 @@ ARG JANS_CONFIG_API_RESOURCES=jans-config-api/server/src/main/resources # note that as we're pulling from a monorepo (with multiple project in it) # we are using partial-clone and sparse-checkout to get the assets -RUN git clone --depth 500 --filter blob:none --no-checkout https://github.com/janssenproject/jans /tmp/jans \ +ARG GIT_CLONE_DEPTH=100 +RUN git clone --depth ${GIT_CLONE_DEPTH} --filter blob:none --no-checkout https://github.com/janssenproject/jans /tmp/jans \ && cd /tmp/jans \ && git sparse-checkout init --cone \ && git checkout ${JANS_SOURCE_VERSION} \ @@ -53,11 +54,13 @@ RUN cd /tmp/jans \ # Python # ====== +# default pip timeout +ARG PIP_TIMEOUT=15 COPY requirements.txt /app/requirements.txt RUN mv /usr/lib/python3.12/EXTERNALLY-MANAGED /usr/lib/python3.12/EXTERNALLY-MANAGED.disabled \ && python3 -m ensurepip \ - && pip3 install --no-cache-dir -U pip wheel setuptools \ - && pip3 install --no-cache-dir -r /app/requirements.txt \ + && pip3 install --no-cache-dir -U pip wheel setuptools --timeout ${PIP_TIMEOUT} \ + && pip3 install --no-cache-dir -r /app/requirements.txt --timeout ${PIP_TIMEOUT} \ && pip3 uninstall -y pip wheel # ======= diff --git a/docker-jans-persistence-loader/scripts/sql_setup.py b/docker-jans-persistence-loader/scripts/sql_setup.py index 8351ca711e7..7cd0fc43b98 100644 --- a/docker-jans-persistence-loader/scripts/sql_setup.py +++ b/docker-jans-persistence-loader/scripts/sql_setup.py @@ -185,13 +185,17 @@ def create_pgsql_indexes(self, table_name: str, column_mapping: dict): self.client.create_index(query) def create_indexes(self): - for table_name, column_mapping in self.client.get_table_mapping().items(): + # exclude tables that created externally https://github.com/JanssenProject/jans/issues/10512 + table_mapping = { + k: v for k, v in self.client.get_table_mapping().items() + if k in self.table_mapping_from_schema() + } + + for table_name, column_mapping in table_mapping.items(): if self.client.dialect == "pgsql": - index_func = self.create_pgsql_indexes + self.create_pgsql_indexes(table_name, column_mapping) else: - index_func = self.create_mysql_indexes - # run the callback - index_func(table_name, column_mapping) + self.create_mysql_indexes(table_name, column_mapping) def create_unique_indexes(self): for table_name, column in [