2026-01-28 19:14:06 +00:00
|
|
|
package php
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"bufio"
|
|
|
|
|
"encoding/json"
|
|
|
|
|
"os"
|
|
|
|
|
"path/filepath"
|
|
|
|
|
"strings"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
// DetectedService represents a service that was detected in a Laravel project.
|
|
|
|
|
type DetectedService string
|
|
|
|
|
|
feat: git command, build improvements, and go fmt git-aware (#74)
* feat(go): make go fmt git-aware by default
- By default, only check changed Go files (modified, staged, untracked)
- Add --all flag to check all files (previous behaviour)
- Reduces noise when running fmt on large codebases
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* feat(build): minimal output by default, add missing i18n
- Default output now shows single line: "Success Built N artifacts (dir)"
- Add --verbose/-v flag to show full detailed output
- Add all missing i18n translations for build commands
- Errors still show failure reason in minimal mode
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* feat: add root-level `core git` command
- Create pkg/gitcmd with git workflow commands as root menu
- Export command builders from pkg/dev (AddCommitCommand, etc.)
- Commands available under both `core git` and `core dev` for compatibility
- Git commands: health, commit, push, pull, work, sync, apply
- GitHub orchestration stays in dev: issues, reviews, ci, impact
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* feat(qa): add docblock coverage checking
Implement docblock/docstring coverage analysis for Go code:
- New `core qa docblock` command to check coverage
- Shows compact file:line list when under threshold
- Integrate with `core go qa` as a default check
- Add --docblock-threshold flag (default 80%)
The checker uses Go AST parsing to find exported symbols
(functions, types, consts, vars) without documentation.
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* fix: address CodeRabbit review feedback
- Fix doc comment: "status" → "health" in gitcmd package
- Implement --check flag for `core go fmt` (exits non-zero if files need formatting)
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* docs: add docstrings for 100% coverage
Add documentation comments to all exported symbols:
- pkg/build: ProjectType constants
- pkg/cli: LogLevel, RenderStyle, TableStyle
- pkg/framework: ServiceFor, MustServiceFor, Core.Core
- pkg/git: GitError.Error, GitError.Unwrap
- pkg/i18n: Handler Match/Handle methods
- pkg/log: Level constants
- pkg/mcp: Tool input/output types
- pkg/php: Service constants, QA types, service methods
- pkg/process: ServiceError.Error
- pkg/repos: RepoType constants
- pkg/setup: ChangeType, ChangeCategory constants
- pkg/workspace: AddWorkspaceCommands
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* chore: standardize line endings to LF
Add .gitattributes to enforce LF line endings for all text files.
Normalize all existing files to use Unix-style line endings.
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* fix: address CodeRabbit review feedback
- cmd_format.go: validate --check/--fix mutual exclusivity, capture stderr
- cmd_docblock.go: return error instead of os.Exit(1) for proper error handling
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* fix: address CodeRabbit review feedback (round 2)
- linuxkit.go: propagate state update errors, handle cmd.Wait() errors in waitForExit
- mcp.go: guard against empty old_string in editDiff to prevent runaway edits
- cmd_docblock.go: log parse errors instead of silently skipping
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
---------
Co-authored-by: Claude Opus 4.5 <noreply@anthropic.com>
2026-02-01 10:48:44 +00:00
|
|
|
// Detected service constants for Laravel projects.
|
2026-01-28 19:14:06 +00:00
|
|
|
const (
|
feat: git command, build improvements, and go fmt git-aware (#74)
* feat(go): make go fmt git-aware by default
- By default, only check changed Go files (modified, staged, untracked)
- Add --all flag to check all files (previous behaviour)
- Reduces noise when running fmt on large codebases
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* feat(build): minimal output by default, add missing i18n
- Default output now shows single line: "Success Built N artifacts (dir)"
- Add --verbose/-v flag to show full detailed output
- Add all missing i18n translations for build commands
- Errors still show failure reason in minimal mode
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* feat: add root-level `core git` command
- Create pkg/gitcmd with git workflow commands as root menu
- Export command builders from pkg/dev (AddCommitCommand, etc.)
- Commands available under both `core git` and `core dev` for compatibility
- Git commands: health, commit, push, pull, work, sync, apply
- GitHub orchestration stays in dev: issues, reviews, ci, impact
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* feat(qa): add docblock coverage checking
Implement docblock/docstring coverage analysis for Go code:
- New `core qa docblock` command to check coverage
- Shows compact file:line list when under threshold
- Integrate with `core go qa` as a default check
- Add --docblock-threshold flag (default 80%)
The checker uses Go AST parsing to find exported symbols
(functions, types, consts, vars) without documentation.
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* fix: address CodeRabbit review feedback
- Fix doc comment: "status" → "health" in gitcmd package
- Implement --check flag for `core go fmt` (exits non-zero if files need formatting)
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* docs: add docstrings for 100% coverage
Add documentation comments to all exported symbols:
- pkg/build: ProjectType constants
- pkg/cli: LogLevel, RenderStyle, TableStyle
- pkg/framework: ServiceFor, MustServiceFor, Core.Core
- pkg/git: GitError.Error, GitError.Unwrap
- pkg/i18n: Handler Match/Handle methods
- pkg/log: Level constants
- pkg/mcp: Tool input/output types
- pkg/php: Service constants, QA types, service methods
- pkg/process: ServiceError.Error
- pkg/repos: RepoType constants
- pkg/setup: ChangeType, ChangeCategory constants
- pkg/workspace: AddWorkspaceCommands
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* chore: standardize line endings to LF
Add .gitattributes to enforce LF line endings for all text files.
Normalize all existing files to use Unix-style line endings.
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* fix: address CodeRabbit review feedback
- cmd_format.go: validate --check/--fix mutual exclusivity, capture stderr
- cmd_docblock.go: return error instead of os.Exit(1) for proper error handling
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* fix: address CodeRabbit review feedback (round 2)
- linuxkit.go: propagate state update errors, handle cmd.Wait() errors in waitForExit
- mcp.go: guard against empty old_string in editDiff to prevent runaway edits
- cmd_docblock.go: log parse errors instead of silently skipping
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
---------
Co-authored-by: Claude Opus 4.5 <noreply@anthropic.com>
2026-02-01 10:48:44 +00:00
|
|
|
// ServiceFrankenPHP indicates FrankenPHP server is detected.
|
2026-01-28 19:14:06 +00:00
|
|
|
ServiceFrankenPHP DetectedService = "frankenphp"
|
feat: git command, build improvements, and go fmt git-aware (#74)
* feat(go): make go fmt git-aware by default
- By default, only check changed Go files (modified, staged, untracked)
- Add --all flag to check all files (previous behaviour)
- Reduces noise when running fmt on large codebases
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* feat(build): minimal output by default, add missing i18n
- Default output now shows single line: "Success Built N artifacts (dir)"
- Add --verbose/-v flag to show full detailed output
- Add all missing i18n translations for build commands
- Errors still show failure reason in minimal mode
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* feat: add root-level `core git` command
- Create pkg/gitcmd with git workflow commands as root menu
- Export command builders from pkg/dev (AddCommitCommand, etc.)
- Commands available under both `core git` and `core dev` for compatibility
- Git commands: health, commit, push, pull, work, sync, apply
- GitHub orchestration stays in dev: issues, reviews, ci, impact
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* feat(qa): add docblock coverage checking
Implement docblock/docstring coverage analysis for Go code:
- New `core qa docblock` command to check coverage
- Shows compact file:line list when under threshold
- Integrate with `core go qa` as a default check
- Add --docblock-threshold flag (default 80%)
The checker uses Go AST parsing to find exported symbols
(functions, types, consts, vars) without documentation.
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* fix: address CodeRabbit review feedback
- Fix doc comment: "status" → "health" in gitcmd package
- Implement --check flag for `core go fmt` (exits non-zero if files need formatting)
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* docs: add docstrings for 100% coverage
Add documentation comments to all exported symbols:
- pkg/build: ProjectType constants
- pkg/cli: LogLevel, RenderStyle, TableStyle
- pkg/framework: ServiceFor, MustServiceFor, Core.Core
- pkg/git: GitError.Error, GitError.Unwrap
- pkg/i18n: Handler Match/Handle methods
- pkg/log: Level constants
- pkg/mcp: Tool input/output types
- pkg/php: Service constants, QA types, service methods
- pkg/process: ServiceError.Error
- pkg/repos: RepoType constants
- pkg/setup: ChangeType, ChangeCategory constants
- pkg/workspace: AddWorkspaceCommands
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* chore: standardize line endings to LF
Add .gitattributes to enforce LF line endings for all text files.
Normalize all existing files to use Unix-style line endings.
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* fix: address CodeRabbit review feedback
- cmd_format.go: validate --check/--fix mutual exclusivity, capture stderr
- cmd_docblock.go: return error instead of os.Exit(1) for proper error handling
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* fix: address CodeRabbit review feedback (round 2)
- linuxkit.go: propagate state update errors, handle cmd.Wait() errors in waitForExit
- mcp.go: guard against empty old_string in editDiff to prevent runaway edits
- cmd_docblock.go: log parse errors instead of silently skipping
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
---------
Co-authored-by: Claude Opus 4.5 <noreply@anthropic.com>
2026-02-01 10:48:44 +00:00
|
|
|
// ServiceVite indicates Vite frontend bundler is detected.
|
|
|
|
|
ServiceVite DetectedService = "vite"
|
|
|
|
|
// ServiceHorizon indicates Laravel Horizon queue dashboard is detected.
|
|
|
|
|
ServiceHorizon DetectedService = "horizon"
|
|
|
|
|
// ServiceReverb indicates Laravel Reverb WebSocket server is detected.
|
|
|
|
|
ServiceReverb DetectedService = "reverb"
|
|
|
|
|
// ServiceRedis indicates Redis cache/queue backend is detected.
|
|
|
|
|
ServiceRedis DetectedService = "redis"
|
2026-01-28 19:14:06 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
|
|
// IsLaravelProject checks if the given directory is a Laravel project.
|
|
|
|
|
// It looks for the presence of artisan file and laravel in composer.json.
|
|
|
|
|
func IsLaravelProject(dir string) bool {
|
|
|
|
|
// Check for artisan file
|
|
|
|
|
artisanPath := filepath.Join(dir, "artisan")
|
|
|
|
|
if _, err := os.Stat(artisanPath); os.IsNotExist(err) {
|
|
|
|
|
return false
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Check composer.json for laravel/framework
|
|
|
|
|
composerPath := filepath.Join(dir, "composer.json")
|
|
|
|
|
data, err := os.ReadFile(composerPath)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return false
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var composer struct {
|
|
|
|
|
Require map[string]string `json:"require"`
|
|
|
|
|
RequireDev map[string]string `json:"require-dev"`
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if err := json.Unmarshal(data, &composer); err != nil {
|
|
|
|
|
return false
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Check for laravel/framework in require
|
|
|
|
|
if _, ok := composer.Require["laravel/framework"]; ok {
|
|
|
|
|
return true
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Also check require-dev (less common but possible)
|
|
|
|
|
if _, ok := composer.RequireDev["laravel/framework"]; ok {
|
|
|
|
|
return true
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return false
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// IsFrankenPHPProject checks if the project is configured for FrankenPHP.
|
|
|
|
|
// It looks for laravel/octane with frankenphp driver.
|
|
|
|
|
func IsFrankenPHPProject(dir string) bool {
|
|
|
|
|
// Check composer.json for laravel/octane
|
|
|
|
|
composerPath := filepath.Join(dir, "composer.json")
|
|
|
|
|
data, err := os.ReadFile(composerPath)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return false
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var composer struct {
|
|
|
|
|
Require map[string]string `json:"require"`
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if err := json.Unmarshal(data, &composer); err != nil {
|
|
|
|
|
return false
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if _, ok := composer.Require["laravel/octane"]; !ok {
|
|
|
|
|
return false
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Check octane config for frankenphp
|
|
|
|
|
configPath := filepath.Join(dir, "config", "octane.php")
|
|
|
|
|
if _, err := os.Stat(configPath); os.IsNotExist(err) {
|
|
|
|
|
// If no config exists but octane is installed, assume frankenphp
|
|
|
|
|
return true
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
configData, err := os.ReadFile(configPath)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return true // Assume frankenphp if we can't read config
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Look for frankenphp in the config
|
|
|
|
|
return strings.Contains(string(configData), "frankenphp")
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// DetectServices detects which services are needed based on project files.
|
|
|
|
|
func DetectServices(dir string) []DetectedService {
|
|
|
|
|
services := []DetectedService{}
|
|
|
|
|
|
|
|
|
|
// FrankenPHP/Octane is always needed for a Laravel dev environment
|
|
|
|
|
if IsFrankenPHPProject(dir) || IsLaravelProject(dir) {
|
|
|
|
|
services = append(services, ServiceFrankenPHP)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Check for Vite
|
|
|
|
|
if hasVite(dir) {
|
|
|
|
|
services = append(services, ServiceVite)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Check for Horizon
|
|
|
|
|
if hasHorizon(dir) {
|
|
|
|
|
services = append(services, ServiceHorizon)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Check for Reverb
|
|
|
|
|
if hasReverb(dir) {
|
|
|
|
|
services = append(services, ServiceReverb)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Check for Redis
|
|
|
|
|
if needsRedis(dir) {
|
|
|
|
|
services = append(services, ServiceRedis)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return services
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// hasVite checks if the project uses Vite.
|
|
|
|
|
func hasVite(dir string) bool {
|
|
|
|
|
viteConfigs := []string{
|
|
|
|
|
"vite.config.js",
|
|
|
|
|
"vite.config.ts",
|
|
|
|
|
"vite.config.mjs",
|
|
|
|
|
"vite.config.mts",
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
for _, config := range viteConfigs {
|
|
|
|
|
if _, err := os.Stat(filepath.Join(dir, config)); err == nil {
|
|
|
|
|
return true
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return false
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// hasHorizon checks if Laravel Horizon is configured.
|
|
|
|
|
func hasHorizon(dir string) bool {
|
|
|
|
|
horizonConfig := filepath.Join(dir, "config", "horizon.php")
|
|
|
|
|
_, err := os.Stat(horizonConfig)
|
|
|
|
|
return err == nil
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// hasReverb checks if Laravel Reverb is configured.
|
|
|
|
|
func hasReverb(dir string) bool {
|
|
|
|
|
reverbConfig := filepath.Join(dir, "config", "reverb.php")
|
|
|
|
|
_, err := os.Stat(reverbConfig)
|
|
|
|
|
return err == nil
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// needsRedis checks if the project uses Redis based on .env configuration.
|
|
|
|
|
func needsRedis(dir string) bool {
|
|
|
|
|
envPath := filepath.Join(dir, ".env")
|
|
|
|
|
file, err := os.Open(envPath)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return false
|
|
|
|
|
}
|
feat: infrastructure packages and lint cleanup (#281)
* ci: consolidate duplicate workflows and merge CodeQL configs
Remove 17 duplicate workflow files that were split copies of the
combined originals. Each family (CI, CodeQL, Coverage, PR Build,
Alpha Release) had the same job duplicated across separate
push/pull_request/schedule/manual trigger files.
Merge codeql.yml and codescan.yml into a single codeql.yml with
a language matrix covering go, javascript-typescript, python,
and actions — matching the previous default setup coverage.
Remaining workflows (one per family):
- ci.yml (push + PR + manual)
- codeql.yml (push + PR + schedule, all languages)
- coverage.yml (push + PR + manual)
- alpha-release.yml (push + manual)
- pr-build.yml (PR + manual)
- release.yml (tag push)
- agent-verify.yml, auto-label.yml, auto-project.yml
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* feat: add collect, config, crypt, plugin packages and fix all lint issues
Add four new infrastructure packages with CLI commands:
- pkg/config: layered configuration (defaults → file → env → flags)
- pkg/crypt: crypto primitives (Argon2id, AES-GCM, ChaCha20, HMAC, checksums)
- pkg/plugin: plugin system with GitHub-based install/update/remove
- pkg/collect: collection subsystem (GitHub, BitcoinTalk, market, papers, excavate)
Fix all golangci-lint issues across the entire codebase (~100 errcheck,
staticcheck SA1012/SA1019/ST1005, unused, ineffassign fixes) so that
`core go qa` passes with 0 issues.
Closes #167, #168, #170, #250, #251, #252, #253, #254, #255, #256
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
---------
Co-authored-by: Claude Opus 4.5 <noreply@anthropic.com>
2026-02-04 11:34:43 +00:00
|
|
|
defer func() { _ = file.Close() }()
|
2026-01-28 19:14:06 +00:00
|
|
|
|
|
|
|
|
scanner := bufio.NewScanner(file)
|
|
|
|
|
for scanner.Scan() {
|
|
|
|
|
line := strings.TrimSpace(scanner.Text())
|
|
|
|
|
if strings.HasPrefix(line, "#") {
|
|
|
|
|
continue
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Check for Redis-related environment variables
|
|
|
|
|
redisIndicators := []string{
|
|
|
|
|
"REDIS_HOST=",
|
|
|
|
|
"CACHE_DRIVER=redis",
|
|
|
|
|
"QUEUE_CONNECTION=redis",
|
|
|
|
|
"SESSION_DRIVER=redis",
|
|
|
|
|
"BROADCAST_DRIVER=redis",
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
for _, indicator := range redisIndicators {
|
|
|
|
|
if strings.HasPrefix(line, indicator) {
|
|
|
|
|
// Check if it's set to localhost or 127.0.0.1
|
|
|
|
|
if strings.Contains(line, "127.0.0.1") || strings.Contains(line, "localhost") ||
|
|
|
|
|
indicator != "REDIS_HOST=" {
|
|
|
|
|
return true
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return false
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// DetectPackageManager detects which package manager is used in the project.
|
|
|
|
|
// Returns "npm", "pnpm", "yarn", or "bun".
|
|
|
|
|
func DetectPackageManager(dir string) string {
|
|
|
|
|
// Check for lock files in order of preference
|
|
|
|
|
lockFiles := []struct {
|
|
|
|
|
file string
|
|
|
|
|
manager string
|
|
|
|
|
}{
|
|
|
|
|
{"bun.lockb", "bun"},
|
|
|
|
|
{"pnpm-lock.yaml", "pnpm"},
|
|
|
|
|
{"yarn.lock", "yarn"},
|
|
|
|
|
{"package-lock.json", "npm"},
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
for _, lf := range lockFiles {
|
|
|
|
|
if _, err := os.Stat(filepath.Join(dir, lf.file)); err == nil {
|
|
|
|
|
return lf.manager
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Default to npm if no lock file found
|
|
|
|
|
return "npm"
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// GetLaravelAppName extracts the application name from Laravel's .env file.
|
|
|
|
|
func GetLaravelAppName(dir string) string {
|
|
|
|
|
envPath := filepath.Join(dir, ".env")
|
|
|
|
|
file, err := os.Open(envPath)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return ""
|
|
|
|
|
}
|
feat: infrastructure packages and lint cleanup (#281)
* ci: consolidate duplicate workflows and merge CodeQL configs
Remove 17 duplicate workflow files that were split copies of the
combined originals. Each family (CI, CodeQL, Coverage, PR Build,
Alpha Release) had the same job duplicated across separate
push/pull_request/schedule/manual trigger files.
Merge codeql.yml and codescan.yml into a single codeql.yml with
a language matrix covering go, javascript-typescript, python,
and actions — matching the previous default setup coverage.
Remaining workflows (one per family):
- ci.yml (push + PR + manual)
- codeql.yml (push + PR + schedule, all languages)
- coverage.yml (push + PR + manual)
- alpha-release.yml (push + manual)
- pr-build.yml (PR + manual)
- release.yml (tag push)
- agent-verify.yml, auto-label.yml, auto-project.yml
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* feat: add collect, config, crypt, plugin packages and fix all lint issues
Add four new infrastructure packages with CLI commands:
- pkg/config: layered configuration (defaults → file → env → flags)
- pkg/crypt: crypto primitives (Argon2id, AES-GCM, ChaCha20, HMAC, checksums)
- pkg/plugin: plugin system with GitHub-based install/update/remove
- pkg/collect: collection subsystem (GitHub, BitcoinTalk, market, papers, excavate)
Fix all golangci-lint issues across the entire codebase (~100 errcheck,
staticcheck SA1012/SA1019/ST1005, unused, ineffassign fixes) so that
`core go qa` passes with 0 issues.
Closes #167, #168, #170, #250, #251, #252, #253, #254, #255, #256
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
---------
Co-authored-by: Claude Opus 4.5 <noreply@anthropic.com>
2026-02-04 11:34:43 +00:00
|
|
|
defer func() { _ = file.Close() }()
|
2026-01-28 19:14:06 +00:00
|
|
|
|
|
|
|
|
scanner := bufio.NewScanner(file)
|
|
|
|
|
for scanner.Scan() {
|
|
|
|
|
line := strings.TrimSpace(scanner.Text())
|
|
|
|
|
if strings.HasPrefix(line, "APP_NAME=") {
|
|
|
|
|
value := strings.TrimPrefix(line, "APP_NAME=")
|
|
|
|
|
// Remove quotes if present
|
|
|
|
|
value = strings.Trim(value, `"'`)
|
|
|
|
|
return value
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return ""
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// GetLaravelAppURL extracts the application URL from Laravel's .env file.
|
|
|
|
|
func GetLaravelAppURL(dir string) string {
|
|
|
|
|
envPath := filepath.Join(dir, ".env")
|
|
|
|
|
file, err := os.Open(envPath)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return ""
|
|
|
|
|
}
|
feat: infrastructure packages and lint cleanup (#281)
* ci: consolidate duplicate workflows and merge CodeQL configs
Remove 17 duplicate workflow files that were split copies of the
combined originals. Each family (CI, CodeQL, Coverage, PR Build,
Alpha Release) had the same job duplicated across separate
push/pull_request/schedule/manual trigger files.
Merge codeql.yml and codescan.yml into a single codeql.yml with
a language matrix covering go, javascript-typescript, python,
and actions — matching the previous default setup coverage.
Remaining workflows (one per family):
- ci.yml (push + PR + manual)
- codeql.yml (push + PR + schedule, all languages)
- coverage.yml (push + PR + manual)
- alpha-release.yml (push + manual)
- pr-build.yml (PR + manual)
- release.yml (tag push)
- agent-verify.yml, auto-label.yml, auto-project.yml
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* feat: add collect, config, crypt, plugin packages and fix all lint issues
Add four new infrastructure packages with CLI commands:
- pkg/config: layered configuration (defaults → file → env → flags)
- pkg/crypt: crypto primitives (Argon2id, AES-GCM, ChaCha20, HMAC, checksums)
- pkg/plugin: plugin system with GitHub-based install/update/remove
- pkg/collect: collection subsystem (GitHub, BitcoinTalk, market, papers, excavate)
Fix all golangci-lint issues across the entire codebase (~100 errcheck,
staticcheck SA1012/SA1019/ST1005, unused, ineffassign fixes) so that
`core go qa` passes with 0 issues.
Closes #167, #168, #170, #250, #251, #252, #253, #254, #255, #256
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
---------
Co-authored-by: Claude Opus 4.5 <noreply@anthropic.com>
2026-02-04 11:34:43 +00:00
|
|
|
defer func() { _ = file.Close() }()
|
2026-01-28 19:14:06 +00:00
|
|
|
|
|
|
|
|
scanner := bufio.NewScanner(file)
|
|
|
|
|
for scanner.Scan() {
|
|
|
|
|
line := strings.TrimSpace(scanner.Text())
|
|
|
|
|
if strings.HasPrefix(line, "APP_URL=") {
|
|
|
|
|
value := strings.TrimPrefix(line, "APP_URL=")
|
|
|
|
|
// Remove quotes if present
|
|
|
|
|
value = strings.Trim(value, `"'`)
|
|
|
|
|
return value
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return ""
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// ExtractDomainFromURL extracts the domain from a URL string.
|
|
|
|
|
func ExtractDomainFromURL(url string) string {
|
|
|
|
|
// Remove protocol
|
|
|
|
|
domain := strings.TrimPrefix(url, "https://")
|
|
|
|
|
domain = strings.TrimPrefix(domain, "http://")
|
|
|
|
|
|
|
|
|
|
// Remove port if present
|
|
|
|
|
if idx := strings.Index(domain, ":"); idx != -1 {
|
|
|
|
|
domain = domain[:idx]
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Remove path if present
|
|
|
|
|
if idx := strings.Index(domain, "/"); idx != -1 {
|
|
|
|
|
domain = domain[:idx]
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return domain
|
|
|
|
|
}
|