mirror of
				https://github.com/open-metadata/OpenMetadata.git
				synced 2025-10-31 18:48:35 +00:00 
			
		
		
		
	 a6d544a5d8
			
		
	
	
		a6d544a5d8
		
			
		
	
	
	
	
		
			
			* Support for RDF, SPARQL, SQL-TO-SPARQL * Tests are working * Add RDF relations tests * improve Knowledge Graph UI, tags , glossary term relations * Lang translations * Fix level depth querying * Add semantic search interfaces , integration into search * cleanup * Update generated TypeScript types * Fix styling * remove duplicated ttl file * model generator cleanup * Update OM - DCAT vocab * Update DataProduct Schema * Improve JsonLD Translator * Update generated TypeScript types * Fix Tests * Fix java checkstyle * Add RDF workflows * fix unit tests * fix e2e --------- Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> Co-authored-by: Chirag Madlani <12962843+chirag-madlani@users.noreply.github.com>
		
			
				
	
	
		
			225 lines
		
	
	
		
			8.9 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			225 lines
		
	
	
		
			8.9 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/bin/bash
 | |
| #  Copyright 2021 Collate
 | |
| #  Licensed under the Apache License, Version 2.0 (the "License");
 | |
| #  you may not use this file except in compliance with the License.
 | |
| #  You may obtain a copy of the License at
 | |
| #  http://www.apache.org/licenses/LICENSE-2.0
 | |
| #  Unless required by applicable law or agreed to in writing, software
 | |
| #  distributed under the License is distributed on an "AS IS" BASIS,
 | |
| #  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | |
| #  See the License for the specific language governing permissions and
 | |
| #  limitations under the License.
 | |
| 
 | |
| cd "$(dirname "${BASH_SOURCE[0]}")" || exit
 | |
| 
 | |
| helpFunction()
 | |
| {
 | |
|    echo ""
 | |
|    echo "Usage: $0 -m mode -d database"
 | |
|    echo "\t-m Running mode: [ui, no-ui]. Default [ui]"
 | |
|    echo "\t-d Database: [mysql, postgresql]. Default [mysql]"
 | |
|    echo "\t-s Skip maven build: [true, false]. Default [false]"
 | |
|    echo "\t-x Open JVM debug port on 5005: [true, false]. Default [false]"
 | |
|    echo "\t-h For usage help"
 | |
|    echo "\t-r For Cleaning DB Volumes. [true, false]. Default [true]"
 | |
|    echo "\t-f Start Fuseki for RDF support: [true, false]. Default [true]"
 | |
|    exit 1 # Exit script after printing help
 | |
| }
 | |
| 
 | |
| while getopts "m:d:s:x:r:f:h" opt
 | |
| do
 | |
|    case "$opt" in
 | |
|       m ) mode="$OPTARG" ;;
 | |
|       d ) database="$OPTARG" ;;
 | |
|       s ) skipMaven="$OPTARG" ;;
 | |
|       x ) debugOM="$OPTARG" ;;
 | |
|       r ) cleanDbVolumes="$OPTARG" ;;
 | |
|       f ) startFuseki="$OPTARG" ;;
 | |
|       h ) helpFunction ;;
 | |
|       ? ) helpFunction ;;
 | |
|    esac
 | |
| done
 | |
| 
 | |
| mode="${mode:=ui}"
 | |
| database="${database:=mysql}"
 | |
| skipMaven="${skipMaven:=false}"
 | |
| debugOM="${debugOM:=false}"
 | |
| authorizationToken="eyJraWQiOiJHYjM4OWEtOWY3Ni1nZGpzLWE5MmotMDI0MmJrOTQzNTYiLCJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiJ9.eyJzdWIiOiJhZG1pbiIsImlzQm90IjpmYWxzZSwiaXNzIjoib3Blbi1tZXRhZGF0YS5vcmciLCJpYXQiOjE2NjM5Mzg0NjIsImVtYWlsIjoiYWRtaW5Ab3Blbm1ldGFkYXRhLm9yZyJ9.tS8um_5DKu7HgzGBzS1VTA5uUjKWOCU0B_j08WXBiEC0mr0zNREkqVfwFDD-d24HlNEbrqioLsBuFRiwIWKc1m_ZlVQbG7P36RUxhuv2vbSp80FKyNM-Tj93FDzq91jsyNmsQhyNv_fNr3TXfzzSPjHt8Go0FMMP66weoKMgW2PbXlhVKwEuXUHyakLLzewm9UMeQaEiRzhiTMU3UkLXcKbYEJJvfNFcLwSl9W8JCO_l0Yj3ud-qt_nQYEZwqW6u5nfdQllN133iikV4fM5QZsMCnm8Rq1mvLR0y9bmJiD7fwM1tmJ791TUWqmKaTnP49U493VanKpUAfzIiOiIbhg"
 | |
| cleanDbVolumes="${cleanDbVolumes:=true}"
 | |
| startFuseki="${startFuseki:=true}"
 | |
| 
 | |
| echo "Running local docker using mode [$mode] database [$database] and skipping maven build [$skipMaven] with cleanDB as [$cleanDbVolumes] and Fuseki [$startFuseki]"
 | |
| 
 | |
| cd ../
 | |
| 
 | |
| echo "Stopping any previous Local Docker Containers"
 | |
| docker compose -f docker/development/docker-compose-postgres.yml down --remove-orphans
 | |
| docker compose -f docker/development/docker-compose.yml down --remove-orphans
 | |
| docker compose -f docker/development/docker-compose-fuseki.yml down --remove-orphans
 | |
| 
 | |
| if [[ $skipMaven == "false" ]]; then
 | |
|     if [[ $mode == "no-ui" ]]; then
 | |
|         echo "Maven Build - Skipping Tests and UI"
 | |
|         mvn -DskipTests -DonlyBackend clean package -pl !openmetadata-ui
 | |
|     else
 | |
|         echo "Maven Build - Skipping Tests"
 | |
|         mvn -DskipTests clean package
 | |
|     fi
 | |
| else
 | |
|     echo "Skipping Maven Build"
 | |
| fi
 | |
| 
 | |
| RESULT=$?
 | |
| if [ $RESULT -ne 0 ]; then
 | |
|   echo "Failed to run Maven build!"
 | |
|   exit 1
 | |
| fi
 | |
| 
 | |
| if [[ $debugOM == "true" ]]; then
 | |
|  export OPENMETADATA_DEBUG=true
 | |
| fi
 | |
| 
 | |
| if [[ $cleanDbVolumes == "true" ]]
 | |
| then
 | |
|   if [[ -d "$PWD/docker/development/docker-volume/" ]]
 | |
|   then
 | |
|       rm -rf $PWD/docker/development/docker-volume
 | |
|     fi
 | |
| fi
 | |
| 
 | |
| if [[ $VIRTUAL_ENV == "" ]];
 | |
| then
 | |
|   echo "Please Use Virtual Environment and make sure to generate Pydantic Models";
 | |
| else
 | |
|   echo "Generating Pydantic Models";
 | |
|   make install_dev generate
 | |
| fi
 | |
| 
 | |
| # Start Fuseki if requested
 | |
| if [[ $startFuseki == "true" ]]; then
 | |
|     echo "Starting Apache Jena Fuseki for RDF support"
 | |
|     docker compose -f docker/development/docker-compose-fuseki.yml up -d
 | |
|     
 | |
|     # Wait for Fuseki to be ready
 | |
|     until curl -s -f "http://localhost:3030/$/ping" > /dev/null 2>&1; do
 | |
|       echo 'Waiting for Fuseki to start...'
 | |
|       sleep 5
 | |
|     done
 | |
|     echo "✔ Fuseki is ready"
 | |
|     
 | |
|     # Set RDF environment variables
 | |
|     export RDF_ENABLED=true
 | |
|     export RDF_STORAGE_TYPE=FUSEKI
 | |
|     export RDF_BASE_URI="https://open-metadata.org/"
 | |
|     export RDF_ENDPOINT="http://localhost:3030/openmetadata"
 | |
|     export RDF_REMOTE_USERNAME="admin"
 | |
|     export RDF_REMOTE_PASSWORD="admin"
 | |
|     export RDF_DATASET="openmetadata"
 | |
| fi
 | |
| 
 | |
| echo "Starting Local Docker Containers"
 | |
| echo "Using ingestion dependency: ${INGESTION_DEPENDENCY:-all}"
 | |
| 
 | |
| if [[ $database == "postgresql" ]]; then
 | |
|     docker compose -f docker/development/docker-compose-postgres.yml build --build-arg INGESTION_DEPENDENCY="${INGESTION_DEPENDENCY:-all}" && docker compose -f docker/development/docker-compose-postgres.yml up -d
 | |
| elif [[ $database == "mysql" ]]; then
 | |
|     docker compose -f docker/development/docker-compose.yml build --build-arg INGESTION_DEPENDENCY="${INGESTION_DEPENDENCY:-all}" && docker compose -f docker/development/docker-compose.yml up -d
 | |
| else
 | |
|     echo "Invalid database type: $database"
 | |
|     exit 1
 | |
| fi
 | |
| 
 | |
| RESULT=$?
 | |
| if [ $RESULT -ne 0 ]; then
 | |
|   echo "Failed to start Docker instances!"
 | |
|   exit 1
 | |
| fi
 | |
| 
 | |
| until curl -s -f "http://localhost:9200/_cat/indices/openmetadata_team_search_index"; do
 | |
|   echo 'Checking if Elastic Search instance is up...'
 | |
|   sleep 5
 | |
| done
 | |
| 
 | |
| until curl -s -f --header 'Authorization: Basic YWRtaW46YWRtaW4=' "http://localhost:8080/api/v1/dags/sample_data"; do
 | |
|   echo 'Checking if Sample Data DAG is reachable...'
 | |
|   sleep 5
 | |
| done
 | |
| 
 | |
| until curl -s -f --header "Authorization: Bearer $authorizationToken" "http://localhost:8585/api/v1/tables"; do
 | |
|   echo 'Checking if OM Server is reachable...'
 | |
|   sleep 5
 | |
| done
 | |
| 
 | |
| curl --location --request PATCH 'localhost:8080/api/v1/dags/sample_data' \
 | |
|   --header 'Authorization: Basic YWRtaW46YWRtaW4=' \
 | |
|   --header 'Content-Type: application/json' \
 | |
|   --data-raw '{
 | |
|         "is_paused": false
 | |
|       }'
 | |
| 
 | |
| curl --location --request PATCH 'localhost:8080/api/v1/dags/extended_sample_data' \
 | |
|   --header 'Authorization: Basic YWRtaW46YWRtaW4=' \
 | |
|   --header 'Content-Type: application/json' \
 | |
|   --data-raw '{
 | |
|         "is_paused": false
 | |
|       }'
 | |
| 
 | |
| echo 'Validate sample data DAG...'
 | |
| sleep 5
 | |
| # This validates the sample data DAG flow
 | |
| make install
 | |
| python docker/validate_compose.py
 | |
| 
 | |
| sleep 5
 | |
| curl --location --request PATCH 'localhost:8080/api/v1/dags/sample_usage' \
 | |
|   --header 'Authorization: Basic YWRtaW46YWRtaW4=' \
 | |
|   --header 'Content-Type: application/json' \
 | |
|   --data-raw '{
 | |
|       "is_paused": false
 | |
|       }'
 | |
| sleep 5
 | |
| curl --location --request PATCH 'localhost:8080/api/v1/dags/index_metadata' \
 | |
|   --header 'Authorization: Basic YWRtaW46YWRtaW4=' \
 | |
|   --header 'Content-Type: application/json' \
 | |
|   --data-raw '{
 | |
|       "is_paused": false
 | |
|       }'
 | |
| sleep 2
 | |
| curl --location --request PATCH 'localhost:8080/api/v1/dags/sample_lineage' \
 | |
|   --header 'Authorization: Basic YWRtaW46YWRtaW4=' \
 | |
|   --header 'Content-Type: application/json' \
 | |
|   --data-raw '{
 | |
|       "is_paused": false
 | |
|       }'
 | |
| 
 | |
| echo "✔running reindexing"
 | |
| # Trigger ElasticSearch ReIndexing from UI
 | |
| curl --location --request POST 'http://localhost:8585/api/v1/apps/trigger/SearchIndexingApplication' \
 | |
| --header 'Authorization: Bearer eyJraWQiOiJHYjM4OWEtOWY3Ni1nZGpzLWE5MmotMDI0MmJrOTQzNTYiLCJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiJ9.eyJzdWIiOiJhZG1pbiIsImlzQm90IjpmYWxzZSwiaXNzIjoib3Blbi1tZXRhZGF0YS5vcmciLCJpYXQiOjE2NjM5Mzg0NjIsImVtYWlsIjoiYWRtaW5Ab3Blbm1ldGFkYXRhLm9yZyJ9.tS8um_5DKu7HgzGBzS1VTA5uUjKWOCU0B_j08WXBiEC0mr0zNREkqVfwFDD-d24HlNEbrqioLsBuFRiwIWKc1m_ZlVQbG7P36RUxhuv2vbSp80FKyNM-Tj93FDzq91jsyNmsQhyNv_fNr3TXfzzSPjHt8Go0FMMP66weoKMgW2PbXlhVKwEuXUHyakLLzewm9UMeQaEiRzhiTMU3UkLXcKbYEJJvfNFcLwSl9W8JCO_l0Yj3ud-qt_nQYEZwqW6u5nfdQllN133iikV4fM5QZsMCnm8Rq1mvLR0y9bmJiD7fwM1tmJ791TUWqmKaTnP49U493VanKpUAfzIiOiIbhg'
 | |
| 
 | |
| sleep 60 # Sleep for 60 seconds to make sure the elasticsearch reindexing from UI finishes
 | |
| 
 | |
| # If RDF is enabled, trigger RDF indexing
 | |
| if [[ $startFuseki == "true" ]]; then
 | |
|     echo "✔running RDF reindexing"
 | |
|     # Trigger RDF ReIndexing from UI  
 | |
|     curl --location --request POST 'http://localhost:8585/api/v1/apps/trigger/RdfIndexApp' \
 | |
|     --header 'Authorization: Bearer eyJraWQiOiJHYjM4OWEtOWY3Ni1nZGpzLWE5MmotMDI0MmJrOTQzNTYiLCJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiJ9.eyJzdWIiOiJhZG1pbiIsImlzQm90IjpmYWxzZSwiaXNzIjoib3Blbi1tZXRhZGF0YS5vcmciLCJpYXQiOjE2NjM5Mzg0NjIsImVtYWlsIjoiYWRtaW5Ab3Blbm1ldGFkYXRhLm9yZyJ9.tS8um_5DKu7HgzGBzS1VTA5uUjKWOCU0B_j08WXBiEC0mr0zNREkqVfwFDD-d24HlNEbrqioLsBuFRiwIWKc1m_ZlVQbG7P36RUxhuv2vbSp80FKyNM-Tj93FDzq91jsyNmsQhyNv_fNr3TXfzzSPjHt8Go0FMMP66weoKMgW2PbXlhVKwEuXUHyakLLzewm9UMeQaEiRzhiTMU3UkLXcKbYEJJvfNFcLwSl9W8JCO_l0Yj3ud-qt_nQYEZwqW6u5nfdQllN133iikV4fM5QZsMCnm8Rq1mvLR0y9bmJiD7fwM1tmJ791TUWqmKaTnP49U493VanKpUAfzIiOiIbhg' \
 | |
|     --header 'Content-Type: application/json' \
 | |
|     --data-raw '{
 | |
|         "entities": ["all"],
 | |
|         "recreateIndex": true,
 | |
|         "batchSize": 100
 | |
|     }'
 | |
|     
 | |
|     sleep 30 # Wait for RDF indexing to complete
 | |
| fi
 | |
| 
 | |
| tput setaf 2
 | |
| echo "✔ OpenMetadata is up and running"
 | |
| if [[ $startFuseki == "true" ]]; then
 | |
|     echo "✔ RDF/Knowledge Graph support is enabled"
 | |
|     echo "  - Fuseki UI: http://localhost:3030"
 | |
|     echo "  - SPARQL endpoint: http://localhost:3030/openmetadata/sparql"
 | |
| fi
 | |
| echo "" |