 131868bdca
			
		
	
	131868bdca
	
	
	
		
			
			Major security, observability, and configuration improvements:
## Security Hardening
- Implemented configurable CORS (no more wildcards)
- Added comprehensive auth middleware for admin endpoints
- Enhanced webhook HMAC validation
- Added input validation and rate limiting
- Security headers and CSP policies
## Configuration Management
- Made N8N webhook URL configurable (WHOOSH_N8N_BASE_URL)
- Replaced all hardcoded endpoints with environment variables
- Added feature flags for LLM vs heuristic composition
- Gitea fetch hardening with EAGER_FILTER and FULL_RESCAN options
## API Completeness
- Implemented GetCouncilComposition function
- Added GET /api/v1/councils/{id} endpoint
- Council artifacts API (POST/GET /api/v1/councils/{id}/artifacts)
- /admin/health/details endpoint with component status
- Database lookup for repository URLs (no hardcoded fallbacks)
## Observability & Performance
- Added OpenTelemetry distributed tracing with goal/pulse correlation
- Performance optimization database indexes
- Comprehensive health monitoring
- Enhanced logging and error handling
## Infrastructure
- Production-ready P2P discovery (replaces mock implementation)
- Removed unused Redis configuration
- Enhanced Docker Swarm integration
- Added migration files for performance indexes
## Code Quality
- Comprehensive input validation
- Graceful error handling and failsafe fallbacks
- Backwards compatibility maintained
- Following security best practices
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
		
	
		
			
				
	
	
		
			86 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Bash
		
	
	
	
	
	
			
		
		
	
	
			86 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Bash
		
	
	
	
	
	
| #!/bin/bash
 | |
| 
 | |
| # Copyright The OpenTelemetry Authors
 | |
| #
 | |
| # 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.
 | |
| 
 | |
| set -euo pipefail
 | |
| 
 | |
| cd $(dirname $0)
 | |
| TOOLS_DIR=$(pwd)/.tools
 | |
| 
 | |
| if [ -z "${GOPATH}" ] ; then
 | |
| 	printf "GOPATH is not defined.\n"
 | |
| 	exit -1
 | |
| fi
 | |
| 
 | |
| if [ ! -d "${GOPATH}" ] ; then
 | |
| 	printf "GOPATH ${GOPATH} is invalid \n"
 | |
| 	exit -1
 | |
| fi
 | |
| 
 | |
| # Pre-requisites
 | |
| if ! git diff --quiet; then \
 | |
| 	git status
 | |
| 	printf "\n\nError: working tree is not clean\n"
 | |
| 	exit -1
 | |
| fi
 | |
| 
 | |
| if [ "$(git tag --contains $(git log -1 --pretty=format:"%H"))" = "" ] ; then
 | |
| 	printf "$(git log -1)"
 | |
| 	printf "\n\nError: HEAD is not pointing to a tagged version"
 | |
| fi
 | |
| 
 | |
| make ${TOOLS_DIR}/gojq
 | |
| 
 | |
| DIR_TMP="${GOPATH}/src/oteltmp/"
 | |
| rm -rf $DIR_TMP
 | |
| mkdir -p $DIR_TMP
 | |
| 
 | |
| printf "Copy examples to ${DIR_TMP}\n"
 | |
| cp -a ./example ${DIR_TMP}
 | |
| 
 | |
| # Update go.mod files
 | |
| printf "Update go.mod: rename module and remove replace\n"
 | |
| 
 | |
| PACKAGE_DIRS=$(find . -mindepth 2 -type f -name 'go.mod' -exec dirname {} \; | egrep 'example' | sed 's/^\.\///' | sort)
 | |
| 
 | |
| for dir in $PACKAGE_DIRS; do
 | |
| 	printf "  Update go.mod for $dir\n"
 | |
| 	(cd "${DIR_TMP}/${dir}" && \
 | |
| 	 # replaces is ("mod1" "mod2" …)
 | |
| 	 replaces=($(go mod edit -json | ${TOOLS_DIR}/gojq '.Replace[].Old.Path')) && \
 | |
| 	 # strip double quotes
 | |
| 	 replaces=("${replaces[@]%\"}") && \
 | |
| 	 replaces=("${replaces[@]#\"}") && \
 | |
| 	 # make an array (-dropreplace=mod1 -dropreplace=mod2 …)
 | |
| 	 dropreplaces=("${replaces[@]/#/-dropreplace=}") && \
 | |
| 	 go mod edit -module "oteltmp/${dir}" "${dropreplaces[@]}" && \
 | |
| 	 go mod tidy)
 | |
| done
 | |
| printf "Update done:\n\n"
 | |
| 
 | |
| # Build directories that contain main package. These directories are different than
 | |
| # directories that contain go.mod files.
 | |
| printf "Build examples:\n"
 | |
| EXAMPLES=$(./get_main_pkgs.sh ./example)
 | |
| for ex in $EXAMPLES; do
 | |
| 	printf "  Build $ex in ${DIR_TMP}/${ex}\n"
 | |
| 	(cd "${DIR_TMP}/${ex}" && \
 | |
| 	 go build .)
 | |
| done
 | |
| 
 | |
| # Cleanup
 | |
| printf "Remove copied files.\n"
 | |
| rm -rf $DIR_TMP
 |