@polymorphism-tech/morph-spec 4.3.1 → 4.3.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bin/morph-spec.js +1 -1
- package/package.json +2 -1
- package/src/commands/project/doctor.js +24 -18
- package/src/commands/project/init.js +15 -5
- package/src/commands/project/update.js +7 -3
- package/src/commands/state/state.js +24 -2
- package/src/core/templates/template-registry.js +1 -1
- package/src/core/workflows/workflow-detector.js +2 -2
- package/stacks/blazor-azure/.claude/commands/morph-apply.md +221 -0
- package/stacks/blazor-azure/.claude/commands/morph-archive.md +79 -0
- package/stacks/blazor-azure/.claude/commands/morph-deploy.md +529 -0
- package/stacks/blazor-azure/.claude/commands/morph-infra.md +209 -0
- package/stacks/blazor-azure/.claude/commands/morph-preflight.md +227 -0
- package/stacks/blazor-azure/.claude/commands/morph-proposal.md +122 -0
- package/stacks/blazor-azure/.claude/commands/morph-status.md +86 -0
- package/stacks/blazor-azure/.claude/commands/morph-troubleshoot.md +122 -0
- package/stacks/blazor-azure/.morph/.morphversion +5 -5
- package/stacks/blazor-azure/.morph/config/config.json +9 -0
- package/stacks/blazor-azure/.morph/project/context/README.md +17 -0
- package/stacks/blazor-azure/.morph/standards/ai-agents/blazor-ui.md +364 -0
- package/stacks/blazor-azure/.morph/standards/ai-agents/production.md +415 -0
- package/stacks/blazor-azure/.morph/standards/ai-agents/setup.md +418 -0
- package/stacks/blazor-azure/.morph/standards/ai-agents/team-orchestration.md +479 -0
- package/stacks/blazor-azure/.morph/standards/ai-agents/workflows.md +354 -0
- package/stacks/blazor-azure/.morph/standards/architecture/ddd/aggregates.md +120 -0
- package/stacks/blazor-azure/.morph/standards/architecture/ddd/entities.md +99 -0
- package/stacks/blazor-azure/.morph/standards/architecture/ddd/value-objects.md +124 -0
- package/stacks/blazor-azure/.morph/standards/backend/api/minimal-api.md +494 -0
- package/stacks/blazor-azure/.morph/standards/backend/api/rest.md +492 -0
- package/stacks/blazor-azure/.morph/standards/backend/api/validation.md +88 -0
- package/stacks/blazor-azure/.morph/standards/backend/authentication/passkeys.md +428 -0
- package/stacks/blazor-azure/.morph/standards/backend/database/ef-core.md +199 -0
- package/stacks/blazor-azure/.morph/standards/backend/database/migrations.md +393 -0
- package/stacks/blazor-azure/.morph/standards/backend/database/postgresql/database.md +352 -0
- package/stacks/blazor-azure/.morph/standards/backend/database/repository-patterns.md +528 -0
- package/stacks/blazor-azure/.morph/standards/backend/database/vector-search-rag.md +541 -0
- package/stacks/blazor-azure/.morph/standards/backend/dotnet/async.md +366 -0
- package/stacks/blazor-azure/.morph/standards/backend/dotnet/core.md +117 -0
- package/stacks/blazor-azure/.morph/standards/backend/dotnet/di.md +439 -0
- package/stacks/blazor-azure/.morph/standards/backend/dotnet/program-cs-checklist.md +92 -0
- package/stacks/blazor-azure/.morph/standards/backend/integrations/asaas/asaas-api.md +216 -0
- package/stacks/blazor-azure/.morph/standards/backend/integrations/clerk/clerk-auth.md +290 -0
- package/stacks/blazor-azure/.morph/standards/backend/integrations/hangfire/hangfire-jobs.md +350 -0
- package/stacks/blazor-azure/.morph/standards/backend/integrations/resend/resend-email.md +385 -0
- package/stacks/blazor-azure/.morph/standards/context/analytics.md +96 -0
- package/stacks/blazor-azure/.morph/standards/context/bundles.md +110 -0
- package/stacks/blazor-azure/.morph/standards/context/priming.md +78 -0
- package/stacks/blazor-azure/.morph/standards/core/architecture.md +185 -0
- package/stacks/blazor-azure/.morph/standards/core/coding.md +214 -0
- package/stacks/blazor-azure/.morph/standards/core/git-branching-strategy.md +403 -0
- package/stacks/blazor-azure/.morph/standards/core/git.md +185 -0
- package/stacks/blazor-azure/.morph/standards/core/testing.md +295 -0
- package/stacks/blazor-azure/.morph/standards/data/nosql/blob-storage.md +102 -0
- package/stacks/blazor-azure/.morph/standards/data/nosql/cache/redis.md +97 -0
- package/stacks/blazor-azure/.morph/standards/data/nosql/cosmos-db.md +118 -0
- package/stacks/blazor-azure/.morph/standards/data/vector-search/azure-ai-search.md +121 -0
- package/stacks/blazor-azure/.morph/standards/data/vector-search/rag-chunking.md +104 -0
- package/stacks/blazor-azure/.morph/standards/frontend/blazor/design-checklist.md +222 -0
- package/stacks/blazor-azure/.morph/standards/frontend/blazor/fluent-ui-setup.md +595 -0
- package/stacks/blazor-azure/.morph/standards/frontend/blazor/fluent-ui.md +137 -0
- package/stacks/blazor-azure/.morph/standards/frontend/blazor/html-conversion.md +184 -0
- package/stacks/blazor-azure/.morph/standards/frontend/blazor/lifecycle.md +195 -0
- package/stacks/blazor-azure/.morph/standards/frontend/blazor/pitfalls.md +198 -0
- package/stacks/blazor-azure/.morph/standards/frontend/blazor/state.md +191 -0
- package/stacks/blazor-azure/.morph/standards/frontend/design-system/animations.md +151 -0
- package/stacks/blazor-azure/.morph/standards/frontend/design-system/naming.md +64 -0
- package/stacks/blazor-azure/.morph/standards/frontend/nextjs/nextjs-patterns.md +198 -0
- package/stacks/blazor-azure/.morph/standards/infrastructure/azure/azure.md +624 -0
- package/stacks/blazor-azure/.morph/standards/infrastructure/azure/bicep/bicep-patterns.md +422 -0
- package/stacks/blazor-azure/.morph/standards/infrastructure/azure/devops/azure-devops-setup.md +516 -0
- package/stacks/blazor-azure/.morph/standards/infrastructure/azure/devops/local-development.md +520 -0
- package/stacks/blazor-azure/.morph/standards/infrastructure/azure/services/functions.md +486 -0
- package/stacks/blazor-azure/.morph/standards/infrastructure/azure/services/service-bus.md +459 -0
- package/stacks/blazor-azure/.morph/standards/infrastructure/azure/services/storage.md +407 -0
- package/stacks/blazor-azure/.morph/standards/infrastructure/docker/easypanel-deploy.md +196 -0
- package/stacks/blazor-azure/.morph/standards/infrastructure/supabase/mcp-setup.md +252 -0
- package/stacks/blazor-azure/.morph/standards/infrastructure/supabase/supabase-auth.md +176 -0
- package/stacks/blazor-azure/.morph/standards/infrastructure/supabase/supabase-pgvector.md +169 -0
- package/stacks/blazor-azure/.morph/standards/infrastructure/supabase/supabase-rls.md +184 -0
- package/stacks/blazor-azure/.morph/standards/infrastructure/supabase/supabase-storage.md +153 -0
- package/stacks/blazor-azure/.morph/standards/integration/api/graphql.md +91 -0
- package/stacks/blazor-azure/.morph/standards/integration/api/grpc.md +114 -0
- package/stacks/blazor-azure/.morph/standards/integration/api/rest-design.md +95 -0
- package/stacks/blazor-azure/.morph/standards/integration/event-driven/cqrs.md +101 -0
- package/stacks/blazor-azure/.morph/standards/integration/event-driven/event-sourcing.md +124 -0
- package/stacks/blazor-azure/.morph/standards/integration/event-driven/service-bus.md +95 -0
- package/stacks/blazor-azure/.morph/standards/observability/logging.md +131 -0
- package/stacks/blazor-azure/.morph/standards/observability/metrics.md +121 -0
- package/stacks/blazor-azure/.morph/standards/observability/monitoring.md +114 -0
- package/stacks/blazor-azure/.morph/standards/observability/tracing.md +132 -0
- package/stacks/blazor-azure/.morph/standards/workflows/parallel-execution.md +112 -0
- package/stacks/blazor-azure/.morph/standards/workflows/thread-management.md +113 -0
- package/stacks/blazor-azure/CLAUDE.md +106 -101
- package/stacks/nextjs-supabase/.claude/commands/morph-apply.md +221 -0
- package/stacks/nextjs-supabase/.claude/commands/morph-archive.md +79 -0
- package/stacks/nextjs-supabase/.claude/commands/morph-deploy.md +529 -0
- package/stacks/nextjs-supabase/.claude/commands/morph-infra.md +209 -0
- package/stacks/nextjs-supabase/.claude/commands/morph-preflight.md +227 -0
- package/stacks/nextjs-supabase/.claude/commands/morph-proposal.md +122 -0
- package/stacks/nextjs-supabase/.claude/commands/morph-status.md +86 -0
- package/stacks/nextjs-supabase/.claude/commands/morph-troubleshoot.md +122 -0
- package/stacks/nextjs-supabase/.morph/.morphversion +5 -0
- package/stacks/nextjs-supabase/.morph/config/agents.json +345 -345
- package/stacks/nextjs-supabase/.morph/config/config.json +9 -0
- package/stacks/nextjs-supabase/.morph/project/context/README.md +17 -0
- package/stacks/nextjs-supabase/.morph/standards/ai-agents/blazor-ui.md +364 -0
- package/stacks/nextjs-supabase/.morph/standards/ai-agents/production.md +415 -0
- package/stacks/nextjs-supabase/.morph/standards/ai-agents/setup.md +418 -0
- package/stacks/nextjs-supabase/.morph/standards/ai-agents/team-orchestration.md +479 -0
- package/stacks/nextjs-supabase/.morph/standards/ai-agents/workflows.md +354 -0
- package/stacks/nextjs-supabase/.morph/standards/architecture/ddd/aggregates.md +120 -0
- package/stacks/nextjs-supabase/.morph/standards/architecture/ddd/entities.md +99 -0
- package/stacks/nextjs-supabase/.morph/standards/architecture/ddd/value-objects.md +124 -0
- package/stacks/nextjs-supabase/.morph/standards/backend/api/minimal-api.md +494 -0
- package/stacks/nextjs-supabase/.morph/standards/backend/api/rest.md +492 -0
- package/stacks/nextjs-supabase/.morph/standards/backend/api/validation.md +88 -0
- package/stacks/nextjs-supabase/.morph/standards/backend/authentication/passkeys.md +428 -0
- package/stacks/nextjs-supabase/.morph/standards/backend/database/ef-core.md +199 -0
- package/stacks/nextjs-supabase/.morph/standards/backend/database/migrations.md +393 -0
- package/stacks/nextjs-supabase/.morph/standards/backend/database/postgresql/database.md +352 -0
- package/stacks/nextjs-supabase/.morph/standards/backend/database/repository-patterns.md +528 -0
- package/stacks/nextjs-supabase/.morph/standards/backend/database/vector-search-rag.md +541 -0
- package/stacks/nextjs-supabase/.morph/standards/backend/dotnet/async.md +366 -0
- package/stacks/nextjs-supabase/.morph/standards/backend/dotnet/core.md +117 -0
- package/stacks/nextjs-supabase/.morph/standards/backend/dotnet/di.md +439 -0
- package/stacks/nextjs-supabase/.morph/standards/backend/dotnet/program-cs-checklist.md +92 -0
- package/stacks/nextjs-supabase/.morph/standards/backend/integrations/asaas/asaas-api.md +216 -0
- package/stacks/nextjs-supabase/.morph/standards/backend/integrations/clerk/clerk-auth.md +290 -0
- package/stacks/nextjs-supabase/.morph/standards/backend/integrations/hangfire/hangfire-jobs.md +350 -0
- package/stacks/nextjs-supabase/.morph/standards/backend/integrations/resend/resend-email.md +385 -0
- package/stacks/nextjs-supabase/.morph/standards/context/analytics.md +96 -0
- package/stacks/nextjs-supabase/.morph/standards/context/bundles.md +110 -0
- package/stacks/nextjs-supabase/.morph/standards/context/priming.md +78 -0
- package/stacks/nextjs-supabase/.morph/standards/core/architecture.md +185 -0
- package/stacks/nextjs-supabase/.morph/standards/core/coding.md +214 -0
- package/stacks/nextjs-supabase/.morph/standards/core/git-branching-strategy.md +403 -0
- package/stacks/nextjs-supabase/.morph/standards/core/git.md +185 -0
- package/stacks/nextjs-supabase/.morph/standards/core/testing.md +295 -0
- package/stacks/nextjs-supabase/.morph/standards/data/nosql/blob-storage.md +102 -0
- package/stacks/nextjs-supabase/.morph/standards/data/nosql/cache/redis.md +97 -0
- package/stacks/nextjs-supabase/.morph/standards/data/nosql/cosmos-db.md +118 -0
- package/stacks/nextjs-supabase/.morph/standards/data/vector-search/azure-ai-search.md +121 -0
- package/stacks/nextjs-supabase/.morph/standards/data/vector-search/rag-chunking.md +104 -0
- package/stacks/nextjs-supabase/.morph/standards/frontend/blazor/design-checklist.md +222 -0
- package/stacks/nextjs-supabase/.morph/standards/frontend/blazor/fluent-ui-setup.md +595 -0
- package/stacks/nextjs-supabase/.morph/standards/frontend/blazor/fluent-ui.md +137 -0
- package/stacks/nextjs-supabase/.morph/standards/frontend/blazor/html-conversion.md +184 -0
- package/stacks/nextjs-supabase/.morph/standards/frontend/blazor/lifecycle.md +195 -0
- package/stacks/nextjs-supabase/.morph/standards/frontend/blazor/pitfalls.md +198 -0
- package/stacks/nextjs-supabase/.morph/standards/frontend/blazor/state.md +191 -0
- package/stacks/nextjs-supabase/.morph/standards/frontend/design-system/animations.md +151 -0
- package/stacks/nextjs-supabase/.morph/standards/frontend/design-system/naming.md +64 -0
- package/stacks/nextjs-supabase/.morph/standards/frontend/nextjs/nextjs-patterns.md +198 -0
- package/stacks/nextjs-supabase/.morph/standards/infrastructure/azure/azure.md +624 -0
- package/stacks/nextjs-supabase/.morph/standards/infrastructure/azure/bicep/bicep-patterns.md +422 -0
- package/stacks/nextjs-supabase/.morph/standards/infrastructure/azure/devops/azure-devops-setup.md +516 -0
- package/stacks/nextjs-supabase/.morph/standards/infrastructure/azure/devops/local-development.md +520 -0
- package/stacks/nextjs-supabase/.morph/standards/infrastructure/azure/services/functions.md +486 -0
- package/stacks/nextjs-supabase/.morph/standards/infrastructure/azure/services/service-bus.md +459 -0
- package/stacks/nextjs-supabase/.morph/standards/infrastructure/azure/services/storage.md +407 -0
- package/stacks/nextjs-supabase/.morph/standards/infrastructure/docker/easypanel-deploy.md +196 -0
- package/stacks/nextjs-supabase/.morph/standards/infrastructure/supabase/mcp-setup.md +252 -0
- package/stacks/nextjs-supabase/.morph/standards/infrastructure/supabase/supabase-auth.md +176 -0
- package/stacks/nextjs-supabase/.morph/standards/infrastructure/supabase/supabase-pgvector.md +169 -0
- package/stacks/nextjs-supabase/.morph/standards/infrastructure/supabase/supabase-rls.md +184 -0
- package/stacks/nextjs-supabase/.morph/standards/infrastructure/supabase/supabase-storage.md +153 -0
- package/stacks/nextjs-supabase/.morph/standards/integration/api/graphql.md +91 -0
- package/stacks/nextjs-supabase/.morph/standards/integration/api/grpc.md +114 -0
- package/stacks/nextjs-supabase/.morph/standards/integration/api/rest-design.md +95 -0
- package/stacks/nextjs-supabase/.morph/standards/integration/event-driven/cqrs.md +101 -0
- package/stacks/nextjs-supabase/.morph/standards/integration/event-driven/event-sourcing.md +124 -0
- package/stacks/nextjs-supabase/.morph/standards/integration/event-driven/service-bus.md +95 -0
- package/stacks/nextjs-supabase/.morph/standards/observability/logging.md +131 -0
- package/stacks/nextjs-supabase/.morph/standards/observability/metrics.md +121 -0
- package/stacks/nextjs-supabase/.morph/standards/observability/monitoring.md +114 -0
- package/stacks/nextjs-supabase/.morph/standards/observability/tracing.md +132 -0
- package/stacks/nextjs-supabase/.morph/standards/workflows/parallel-execution.md +112 -0
- package/stacks/nextjs-supabase/.morph/standards/workflows/thread-management.md +113 -0
- package/stacks/nextjs-supabase/CLAUDE.md +69 -63
- package/stacks/blazor-azure/.morph/config/config.template.json +0 -122
- package/stacks/blazor-azure/.morph/hooks/pre-commit/tests-csharp.sh +0 -61
- package/stacks/blazor-azure/.morph/project.md +0 -160
- package/stacks/blazor-azure/.morph/state.json +0 -18
- package/stacks/blazor-azure/.morph/templates/.gitkeep +0 -0
- package/stacks/blazor-azure/.morph/templates/infrastructure/github/workflows/cd-prod.yml.hbs +0 -41
- package/stacks/blazor-azure/.morph/templates/infrastructure/github/workflows/cd-staging.yml.hbs +0 -24
- package/stacks/blazor-azure/.morph/templates/infrastructure/github/workflows/ci-build.yml.hbs +0 -23
- package/stacks/nextjs-supabase/.morph/config/config.template.json +0 -92
- package/stacks/nextjs-supabase/.morph/hooks/pre-commit/tests-typescript.sh +0 -61
- package/stacks/nextjs-supabase/.morph/project.md +0 -168
- package/stacks/nextjs-supabase/.morph/templates/.gitkeep +0 -0
- package/stacks/nextjs-supabase/.morph/templates/infrastructure/github/workflows/cd-prod.yml.hbs +0 -22
- package/stacks/nextjs-supabase/.morph/templates/infrastructure/github/workflows/cd-staging.yml.hbs +0 -22
- package/stacks/nextjs-supabase/.morph/templates/infrastructure/github/workflows/ci-build.yml.hbs +0 -35
|
@@ -0,0 +1,132 @@
|
|
|
1
|
+
# Observability Standard: Distributed Tracing
|
|
2
|
+
|
|
3
|
+
## Overview
|
|
4
|
+
OpenTelemetry distributed tracing for cross-service correlation and performance analysis.
|
|
5
|
+
|
|
6
|
+
## OpenTelemetry Setup
|
|
7
|
+
|
|
8
|
+
### Packages
|
|
9
|
+
```xml
|
|
10
|
+
<PackageReference Include="OpenTelemetry.Extensions.Hosting" Version="1.*" />
|
|
11
|
+
<PackageReference Include="OpenTelemetry.Instrumentation.AspNetCore" Version="1.*" />
|
|
12
|
+
<PackageReference Include="OpenTelemetry.Instrumentation.Http" Version="1.*" />
|
|
13
|
+
<PackageReference Include="OpenTelemetry.Instrumentation.SqlClient" Version="1.*" />
|
|
14
|
+
<PackageReference Include="Azure.Monitor.OpenTelemetry.AspNetCore" Version="1.*" />
|
|
15
|
+
```
|
|
16
|
+
|
|
17
|
+
### Program.cs Configuration
|
|
18
|
+
```csharp
|
|
19
|
+
builder.Services.AddOpenTelemetry()
|
|
20
|
+
.WithTracing(tracing =>
|
|
21
|
+
{
|
|
22
|
+
tracing
|
|
23
|
+
.AddAspNetCoreInstrumentation(opts =>
|
|
24
|
+
{
|
|
25
|
+
opts.RecordException = true;
|
|
26
|
+
opts.Filter = ctx => !ctx.Request.Path.StartsWithSegments("/health");
|
|
27
|
+
})
|
|
28
|
+
.AddHttpClientInstrumentation()
|
|
29
|
+
.AddSqlClientInstrumentation(opts => opts.SetDbStatementForText = true)
|
|
30
|
+
.AddSource(ActivitySource.Name) // Custom activities
|
|
31
|
+
.AddAzureMonitorTraceExporter(opts =>
|
|
32
|
+
{
|
|
33
|
+
opts.ConnectionString = config["ApplicationInsights:ConnectionString"];
|
|
34
|
+
});
|
|
35
|
+
});
|
|
36
|
+
|
|
37
|
+
// Custom ActivitySource for domain operations
|
|
38
|
+
public static class Telemetry
|
|
39
|
+
{
|
|
40
|
+
public static readonly ActivitySource ActivitySource = new("MyApp", "1.0.0");
|
|
41
|
+
}
|
|
42
|
+
```
|
|
43
|
+
|
|
44
|
+
## Custom Span Creation
|
|
45
|
+
|
|
46
|
+
### Service Method Tracing
|
|
47
|
+
```csharp
|
|
48
|
+
public async Task<Order> ProcessOrderAsync(CreateOrderCommand command)
|
|
49
|
+
{
|
|
50
|
+
using var activity = Telemetry.ActivitySource.StartActivity("ProcessOrder");
|
|
51
|
+
activity?.SetTag("order.userId", command.UserId.ToString());
|
|
52
|
+
activity?.SetTag("order.itemCount", command.Items.Count.ToString());
|
|
53
|
+
|
|
54
|
+
try
|
|
55
|
+
{
|
|
56
|
+
var order = await _repository.CreateAsync(command);
|
|
57
|
+
activity?.SetTag("order.id", order.Id.ToString());
|
|
58
|
+
activity?.SetStatus(ActivityStatusCode.Ok);
|
|
59
|
+
return order;
|
|
60
|
+
}
|
|
61
|
+
catch (Exception ex)
|
|
62
|
+
{
|
|
63
|
+
activity?.SetStatus(ActivityStatusCode.Error, ex.Message);
|
|
64
|
+
activity?.RecordException(ex);
|
|
65
|
+
throw;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
```
|
|
69
|
+
|
|
70
|
+
### Baggage (Cross-Service Context)
|
|
71
|
+
```csharp
|
|
72
|
+
// Set correlation ID in baggage (propagates across HTTP calls)
|
|
73
|
+
Activity.Current?.SetBaggage("correlationId", correlationId);
|
|
74
|
+
Activity.Current?.SetBaggage("userId", userId.ToString());
|
|
75
|
+
|
|
76
|
+
// Read baggage downstream
|
|
77
|
+
var correlationId = Activity.Current?.GetBaggageItem("correlationId");
|
|
78
|
+
```
|
|
79
|
+
|
|
80
|
+
## Trace Context Propagation
|
|
81
|
+
|
|
82
|
+
### HTTP Client (auto-propagated)
|
|
83
|
+
```csharp
|
|
84
|
+
// HttpClient automatically propagates W3C trace context
|
|
85
|
+
// Configure in DI:
|
|
86
|
+
builder.Services.AddHttpClient("ExternalApi")
|
|
87
|
+
.AddOpenTelemetryInstrumentation();
|
|
88
|
+
```
|
|
89
|
+
|
|
90
|
+
### Service Bus (manual propagation)
|
|
91
|
+
```csharp
|
|
92
|
+
// Sender: inject trace context into message properties
|
|
93
|
+
var message = new ServiceBusMessage(body);
|
|
94
|
+
var activity = Activity.Current;
|
|
95
|
+
if (activity != null)
|
|
96
|
+
{
|
|
97
|
+
message.ApplicationProperties["traceparent"] = activity.Id;
|
|
98
|
+
message.ApplicationProperties["tracestate"] = activity.TraceStateString;
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
// Receiver: restore trace context from message
|
|
102
|
+
if (message.ApplicationProperties.TryGetValue("traceparent", out var traceparent))
|
|
103
|
+
{
|
|
104
|
+
using var linkedActivity = Telemetry.ActivitySource.StartActivity(
|
|
105
|
+
"ProcessMessage",
|
|
106
|
+
ActivityKind.Consumer,
|
|
107
|
+
parentId: traceparent.ToString()!);
|
|
108
|
+
await ProcessAsync(message);
|
|
109
|
+
}
|
|
110
|
+
```
|
|
111
|
+
|
|
112
|
+
## Trace Sampling Strategy
|
|
113
|
+
|
|
114
|
+
| Environment | Strategy | Rate |
|
|
115
|
+
|-------------|----------|------|
|
|
116
|
+
| Development | Always | 100% |
|
|
117
|
+
| Staging | Adaptive | 10% + errors |
|
|
118
|
+
| Production | Adaptive | 5% + errors |
|
|
119
|
+
|
|
120
|
+
```csharp
|
|
121
|
+
// Production adaptive sampling (errors always sampled)
|
|
122
|
+
.AddAspNetCoreInstrumentation(opts =>
|
|
123
|
+
{
|
|
124
|
+
opts.Enrich = (activity, eventName, obj) =>
|
|
125
|
+
{
|
|
126
|
+
if (obj is HttpResponse response && response.StatusCode >= 400)
|
|
127
|
+
{
|
|
128
|
+
activity.SetSampled(true); // Always sample errors
|
|
129
|
+
}
|
|
130
|
+
};
|
|
131
|
+
})
|
|
132
|
+
```
|
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
# Workflow Standard: Parallel Execution
|
|
2
|
+
|
|
3
|
+
## When to Use Parallel Execution
|
|
4
|
+
|
|
5
|
+
| Condition | Decision |
|
|
6
|
+
|-----------|----------|
|
|
7
|
+
| 5+ independent tasks | Use P-Threads |
|
|
8
|
+
| Multi-domain (backend + frontend + infra) | Use P-Threads with squad templates |
|
|
9
|
+
| 15+ files to create | Use P-Threads |
|
|
10
|
+
| Tasks have zero dependency overlap | Use P-Threads |
|
|
11
|
+
| Tasks share file scope | Do NOT parallelize |
|
|
12
|
+
| Sequential data flow required | Do NOT parallelize |
|
|
13
|
+
|
|
14
|
+
## Parallelization Planning
|
|
15
|
+
|
|
16
|
+
### Step 1: Dependency Analysis
|
|
17
|
+
```bash
|
|
18
|
+
morph-spec detect-workflow user-auth
|
|
19
|
+
|
|
20
|
+
# Identifies: parallelizable tasks, sequential chains, waves
|
|
21
|
+
```
|
|
22
|
+
|
|
23
|
+
### Step 2: File Scope Assignment
|
|
24
|
+
Assign exclusive file ownership to each parallel worker:
|
|
25
|
+
|
|
26
|
+
```
|
|
27
|
+
Worker A (Backend): Entities/, Services/, Controllers/, DTOs/
|
|
28
|
+
Worker B (Frontend): Pages/, Components/, CSS/
|
|
29
|
+
Worker C (Infra): infra/bicep/, .github/workflows/
|
|
30
|
+
```
|
|
31
|
+
|
|
32
|
+
No overlap allowed. If overlap is unavoidable, make it sequential.
|
|
33
|
+
|
|
34
|
+
### Step 3: Choose Squad Template
|
|
35
|
+
```bash
|
|
36
|
+
morph-spec squad-template use full-stack --feature=user-auth
|
|
37
|
+
|
|
38
|
+
# Creates execution plan based on full-stack.json template:
|
|
39
|
+
# - dotnet-senior (backend lead)
|
|
40
|
+
# - blazor-builder (frontend lead)
|
|
41
|
+
# - bicep-architect (infra lead)
|
|
42
|
+
# - thread-orchestrator (coordinator)
|
|
43
|
+
```
|
|
44
|
+
|
|
45
|
+
## Execution Flow
|
|
46
|
+
|
|
47
|
+
```
|
|
48
|
+
Orchestrator
|
|
49
|
+
│
|
|
50
|
+
├── spawn parallel: Worker A (files: Entities/, Services/)
|
|
51
|
+
├── spawn parallel: Worker B (files: Pages/, Components/)
|
|
52
|
+
└── spawn parallel: Worker C (files: infra/)
|
|
53
|
+
│
|
|
54
|
+
│ [Workers execute concurrently — no interaction]
|
|
55
|
+
│
|
|
56
|
+
├── wait-all (poll or explicit sync)
|
|
57
|
+
│
|
|
58
|
+
├── merge results (check for conflicts)
|
|
59
|
+
├── run integration validation
|
|
60
|
+
└── report consolidated output
|
|
61
|
+
```
|
|
62
|
+
|
|
63
|
+
## Conflict Resolution
|
|
64
|
+
|
|
65
|
+
### File Conflicts (two workers wrote same file)
|
|
66
|
+
```bash
|
|
67
|
+
# This should NOT happen if scopes are properly defined
|
|
68
|
+
# If it does:
|
|
69
|
+
morph-spec agents review aggregate user-auth \
|
|
70
|
+
--agents=dotnet-senior,blazor-builder \
|
|
71
|
+
--strategy=best-of-n
|
|
72
|
+
```
|
|
73
|
+
|
|
74
|
+
### Interface Mismatches (A expects contract B didn't fulfill)
|
|
75
|
+
- Document the mismatch in the coordinator report
|
|
76
|
+
- Fix in post-merge sequential step
|
|
77
|
+
- Update contracts.cs to reflect actual implementation
|
|
78
|
+
|
|
79
|
+
## Fusion vs Parallel
|
|
80
|
+
|
|
81
|
+
| Aspect | Parallel (P-Thread) | Fusion (F-Thread) |
|
|
82
|
+
|--------|--------------------|--------------------|
|
|
83
|
+
| Goal | Divide scope | Compete on same scope |
|
|
84
|
+
| Output | Different files | Same files, best one wins |
|
|
85
|
+
| Workers collaborate? | No | No |
|
|
86
|
+
| Merge | Combine all files | Select best implementation |
|
|
87
|
+
| Use case | Large features | Design decisions, quality optimization |
|
|
88
|
+
|
|
89
|
+
## Configuration
|
|
90
|
+
```json
|
|
91
|
+
// llm-interaction.json
|
|
92
|
+
{
|
|
93
|
+
"parallelExecution": {
|
|
94
|
+
"enabled": true,
|
|
95
|
+
"maxConcurrent": 3,
|
|
96
|
+
"defaultStrategy": "best-of-n"
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
```
|
|
100
|
+
|
|
101
|
+
## Squad Templates
|
|
102
|
+
|
|
103
|
+
Pre-defined squad configurations in `framework/squad-templates/`:
|
|
104
|
+
- `full-stack.json` — Backend + Frontend + Infra (6 agents)
|
|
105
|
+
- `backend-only.json` — Backend specialists only (4 agents)
|
|
106
|
+
- `frontend-only.json` — Frontend specialists only (3 agents)
|
|
107
|
+
|
|
108
|
+
```bash
|
|
109
|
+
morph-spec squad-template list
|
|
110
|
+
morph-spec squad-template show full-stack
|
|
111
|
+
morph-spec squad-template use full-stack --feature=user-auth
|
|
112
|
+
```
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
# Workflow Standard: Thread Management
|
|
2
|
+
|
|
3
|
+
## Thread Types
|
|
4
|
+
|
|
5
|
+
| Type | Code | Purpose | Lifecycle |
|
|
6
|
+
|------|------|---------|-----------|
|
|
7
|
+
| Base | B-Thread | Default implementation thread | Bounded by feature phase |
|
|
8
|
+
| Parallel | P-Thread | Concurrent isolated execution | Short (1 task scope) |
|
|
9
|
+
| Fusion | F-Thread | Best-of-N competing implementations | Short (1 prompt scope) |
|
|
10
|
+
| Long-Running | L-Thread | Multi-session persistent work | Days/weeks |
|
|
11
|
+
| Zero-Touch | Z-Thread | Fully autonomous execution | Bounded by trust level |
|
|
12
|
+
|
|
13
|
+
## Thread Lifecycle
|
|
14
|
+
|
|
15
|
+
```
|
|
16
|
+
pending → running → completed
|
|
17
|
+
→ failed → (retry) → running
|
|
18
|
+
→ killed
|
|
19
|
+
```
|
|
20
|
+
|
|
21
|
+
## Creating Threads
|
|
22
|
+
```bash
|
|
23
|
+
# Create a base thread (default)
|
|
24
|
+
morph-spec threads status morph-next-gen
|
|
25
|
+
|
|
26
|
+
# Create parallel threads for feature
|
|
27
|
+
morph-spec spawn-team morph-next-gen --parallel backend,frontend,infra
|
|
28
|
+
|
|
29
|
+
# Create fusion thread
|
|
30
|
+
morph-spec agents fuse \
|
|
31
|
+
--prompt "Implement caching strategy for UserService" \
|
|
32
|
+
--count=3 \
|
|
33
|
+
--strategy=best-of-n \
|
|
34
|
+
--feature=morph-next-gen
|
|
35
|
+
```
|
|
36
|
+
|
|
37
|
+
## Thread State in state.json
|
|
38
|
+
```json
|
|
39
|
+
{
|
|
40
|
+
"threads": {
|
|
41
|
+
"thread-abc12345": {
|
|
42
|
+
"id": "thread-abc12345",
|
|
43
|
+
"type": "parallel",
|
|
44
|
+
"agent": "dotnet-senior",
|
|
45
|
+
"feature": "user-auth",
|
|
46
|
+
"status": "running",
|
|
47
|
+
"startedAt": "2026-02-19T00:00:00Z",
|
|
48
|
+
"events": [
|
|
49
|
+
{ "type": "started", "timestamp": "..." },
|
|
50
|
+
{ "type": "checkpoint_passed", "timestamp": "...", "checkpointNum": 1 }
|
|
51
|
+
],
|
|
52
|
+
"metrics": {
|
|
53
|
+
"tasksCompleted": 3,
|
|
54
|
+
"checkpointsPassed": 1,
|
|
55
|
+
"errors": 0
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
```
|
|
61
|
+
|
|
62
|
+
## Parallel Execution Rules (P-Threads)
|
|
63
|
+
|
|
64
|
+
1. **File scope isolation**: Each P-Thread has exclusive write access to its files
|
|
65
|
+
2. **No cross-thread dependencies**: P-Thread tasks are self-contained
|
|
66
|
+
3. **Shared read access**: All P-Threads can read spec.md, standards, contracts
|
|
67
|
+
4. **Merge on completion**: Coordinator merges results after all P-Threads complete
|
|
68
|
+
5. **Max concurrent**: Default 3, max 5 (configurable in llm-interaction.json)
|
|
69
|
+
|
|
70
|
+
## Dependency Analysis
|
|
71
|
+
```bash
|
|
72
|
+
# Analyze task dependencies for parallel opportunities
|
|
73
|
+
morph-spec detect-workflow morph-next-gen
|
|
74
|
+
|
|
75
|
+
# Output:
|
|
76
|
+
# Parallelizable tasks: T001, T002, T003 (no dependencies)
|
|
77
|
+
# Sequential: T004 (depends on T001), T005 (depends on T002)
|
|
78
|
+
# Execution plan:
|
|
79
|
+
# Wave 1: [T001, T002, T003] (parallel)
|
|
80
|
+
# Wave 2: [T004, T005] (parallel, after wave 1)
|
|
81
|
+
# Wave 3: [T006] (sequential)
|
|
82
|
+
```
|
|
83
|
+
|
|
84
|
+
## Long-Running Threads (L-Threads)
|
|
85
|
+
|
|
86
|
+
### Stop Hooks
|
|
87
|
+
L-Threads run periodic stop hooks every 30 minutes:
|
|
88
|
+
```json
|
|
89
|
+
// llm-interaction.json
|
|
90
|
+
{
|
|
91
|
+
"stopHooks": {
|
|
92
|
+
"enabled": true,
|
|
93
|
+
"interval": 30,
|
|
94
|
+
"maxRetries": 5,
|
|
95
|
+
"hooks": ["validate-and-continue", "validate-checkpoints"]
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
```
|
|
99
|
+
|
|
100
|
+
### Resume Pattern
|
|
101
|
+
```bash
|
|
102
|
+
# Resume L-Thread from bundle
|
|
103
|
+
morph-spec bundle load morph-next-gen
|
|
104
|
+
# Load resume context, continue from checkpoint
|
|
105
|
+
```
|
|
106
|
+
|
|
107
|
+
## Monitoring
|
|
108
|
+
```bash
|
|
109
|
+
morph-spec threads list morph-next-gen
|
|
110
|
+
morph-spec threads analytics morph-next-gen
|
|
111
|
+
morph-spec threads wait-all morph-next-gen
|
|
112
|
+
morph-spec threads wait-any morph-next-gen
|
|
113
|
+
```
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
# MORPH-SPEC -
|
|
1
|
+
# MORPH-SPEC - Claude Code Instructions
|
|
2
2
|
|
|
3
3
|
> by Polymorphism Tech
|
|
4
4
|
|
|
5
|
-
Spec-driven development system. Specialized agent hub for
|
|
5
|
+
Spec-driven development system. Specialized agent hub for multi-stack projects with Infrastructure as Code.
|
|
6
6
|
|
|
7
7
|
---
|
|
8
8
|
|
|
@@ -12,15 +12,15 @@ Spec-driven development system. Specialized agent hub for .NET 10 Minimal API +
|
|
|
12
12
|
- Skip to code without a specification
|
|
13
13
|
- Implement without design approval
|
|
14
14
|
- Ignore standards in `.morph/standards/`
|
|
15
|
-
- Create infrastructure manually
|
|
15
|
+
- Create infrastructure manually
|
|
16
16
|
- Generate code without defined contracts
|
|
17
17
|
|
|
18
18
|
### ALWAYS:
|
|
19
19
|
- Follow the 5 mandatory phases
|
|
20
|
-
- Generate outputs in `.morph/
|
|
20
|
+
- Generate outputs in `.morph/project/outputs/{feature}/`
|
|
21
21
|
- Document decisions in `decisions.md`
|
|
22
22
|
- Checkpoint every 3 implemented tasks
|
|
23
|
-
- Use Infrastructure as Code
|
|
23
|
+
- Use Infrastructure as Code
|
|
24
24
|
|
|
25
25
|
---
|
|
26
26
|
|
|
@@ -28,8 +28,8 @@ Spec-driven development system. Specialized agent hub for .NET 10 Minimal API +
|
|
|
28
28
|
|
|
29
29
|
| Phase | Trigger | Actions | Output | Pause? |
|
|
30
30
|
|-------|---------|---------|--------|--------|
|
|
31
|
-
| **1. SETUP** | Feature request | Read project
|
|
32
|
-
| **2. DESIGN** | Setup done | Spec + contracts + decisions + costs
|
|
31
|
+
| **1. SETUP** | Feature request | Read project context, identify stack, activate agents, create folder | proposal.md | No |
|
|
32
|
+
| **2. DESIGN** | Setup done | Spec + contracts + decisions + costs | spec.md, contracts, decisions.md | **Yes** |
|
|
33
33
|
| **3. CLARIFY** | Design approved | Ambiguities, questions, edge cases | Updated spec | No |
|
|
34
34
|
| **4. TASKS** | Clarifications resolved | Break into tasks, ordering, checkpoints, dependencies | tasks.md | **Yes** |
|
|
35
35
|
| **5. IMPLEMENT** | Tasks approved | Task by task, checkpoint every 3, recap | Code + recap.md | No |
|
|
@@ -42,68 +42,79 @@ Spec-driven development system. Specialized agent hub for .NET 10 Minimal API +
|
|
|
42
42
|
project/
|
|
43
43
|
├── CLAUDE.md
|
|
44
44
|
├── .morph/
|
|
45
|
-
│ ├── project.md # Context
|
|
46
45
|
│ ├── config/ # config.json, agents.json
|
|
47
|
-
│ ├── standards/ #
|
|
46
|
+
│ ├── standards/ # coding, architecture, stack-specific
|
|
48
47
|
│ ├── templates/ # Output templates
|
|
49
|
-
│ ├──
|
|
50
|
-
│ ├──
|
|
51
|
-
│ │ ├──
|
|
52
|
-
│ │
|
|
53
|
-
│
|
|
54
|
-
├── .
|
|
55
|
-
|
|
56
|
-
│ ├── api/ # .NET 10 Minimal API
|
|
57
|
-
│ └── web/ # Next.js 15 App Router
|
|
58
|
-
├── supabase/ # Migrations, seeds, RLS policies
|
|
59
|
-
├── docker-compose.yml # Local dev environment
|
|
60
|
-
└── Dockerfile.* # Production builds
|
|
48
|
+
│ ├── project/
|
|
49
|
+
│ │ ├── context/ # detection-log.md, project.md
|
|
50
|
+
│ │ ├── standards/ # inferred.md, overrides.md
|
|
51
|
+
│ │ └── outputs/{feature}/ # Features in development
|
|
52
|
+
│ │ ├── proposal.md, spec.md, tasks.md
|
|
53
|
+
│ │ ├── contracts, decisions.md, recap.md
|
|
54
|
+
└── .claude/commands/ # Slash commands
|
|
61
55
|
```
|
|
62
56
|
|
|
63
57
|
---
|
|
64
58
|
|
|
65
59
|
## AGENTS
|
|
66
60
|
|
|
67
|
-
###
|
|
61
|
+
### Tier 1 — Orchestrators (Always Active)
|
|
68
62
|
|
|
69
63
|
| Agent | Responsibilities |
|
|
70
64
|
|-------|-----------------|
|
|
71
|
-
| **Standards Architect** | Standards, naming, review |
|
|
72
|
-
| **
|
|
73
|
-
| **
|
|
65
|
+
| **Standards Architect** | Standards, naming, review, cross-cutting concerns |
|
|
66
|
+
| **AI System Architect** | Agent systems, AI integrations, LLM orchestration |
|
|
67
|
+
| **Thread Orchestrator** | Parallel execution, thread management, context optimization |
|
|
74
68
|
|
|
75
|
-
###
|
|
69
|
+
### Tier 2 — Domain Leaders
|
|
76
70
|
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
|
86
|
-
|
|
87
|
-
|
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
71
|
+
| Agent | Responsibilities |
|
|
72
|
+
|-------|-----------------|
|
|
73
|
+
| **Tech Lead** | Architecture decisions, code quality, task breakdown |
|
|
74
|
+
| **DevOps Engineer** | CI/CD, deployment pipelines, infrastructure |
|
|
75
|
+
| **QA Lead** | Test strategies, validation, quality gates |
|
|
76
|
+
|
|
77
|
+
### Tier 3 — Specialists (Activated by keywords)
|
|
78
|
+
|
|
79
|
+
| Agent | Keywords |
|
|
80
|
+
|-------|---------|
|
|
81
|
+
| **Next.js Expert** | nextjs, react, frontend, app router, pages |
|
|
82
|
+
| **Blazor Builder** | blazor, razor, mudblazor, fluent ui |
|
|
83
|
+
| **API Designer** | api, endpoint, rest, openapi, swagger |
|
|
84
|
+
| **.NET Senior** | dotnet, csharp, minimal api, ef core |
|
|
85
|
+
| **EF Modeler** | entity framework, migrations, dbcontext |
|
|
86
|
+
| **Azure Architect** | azure, container apps, bicep, app service |
|
|
87
|
+
| **Bicep Architect** | bicep, iac, arm template, azure resources |
|
|
88
|
+
| **Azure Deploy Specialist** | deploy, ci/cd, github actions, azure devops |
|
|
89
|
+
| **Container Specialist** | docker, dockerfile, compose, kubernetes |
|
|
90
|
+
| **Supabase Expert** | supabase, postgresql, rls, realtime, pgvector |
|
|
91
|
+
| **Azure Identity** | auth, authentication, entra id, jwt, oauth |
|
|
92
|
+
| **Clerk Auth** | clerk, auth0, authentication, social login |
|
|
93
|
+
| **Asaas Financial** | payment, billing, subscription, asaas |
|
|
94
|
+
| **Resend Email** | email, resend, smtp, notifications |
|
|
95
|
+
| **Hangfire Orchestrator** | background jobs, queue, scheduling, hangfire |
|
|
96
|
+
| **MS Agent Expert** | semantic kernel, microsoft agents, ai pipeline |
|
|
97
|
+
| **UI/UX Designer** | design, ux, wireframe, mockup, figma |
|
|
98
|
+
| **SEO Growth Hacker** | seo, performance, analytics, lighthouse |
|
|
99
|
+
| **PO/PM Advisor** | product, roadmap, requirements, user stories |
|
|
100
|
+
| **Prompt Engineer** | prompts, system prompts, llm, few-shot |
|
|
101
|
+
| **Context Optimizer** | context window, token optimization, chunking |
|
|
102
|
+
| **Vector Search Expert** | vector db, embeddings, semantic search, rag |
|
|
103
|
+
| **Observability Expert** | logging, tracing, metrics, opentelemetry |
|
|
104
|
+
| **Code Analyzer** | refactor, analysis, code review, complexity |
|
|
105
|
+
| **Testing Specialist** | tests, coverage, tdd, bdd, vitest, jest, xunit |
|
|
106
|
+
|
|
107
|
+
### Tier 4 — Validators
|
|
94
108
|
|
|
95
|
-
|
|
|
96
|
-
|
|
97
|
-
|
|
|
98
|
-
| Production containers | Dockerfiles + EasyPanel |
|
|
99
|
-
| Supabase (DB, Auth, Storage) | Supabase Cloud (managed) |
|
|
100
|
-
| CI/CD | GitHub Actions + EasyPanel auto-deploy |
|
|
109
|
+
| Agent | Responsibilities |
|
|
110
|
+
|-------|-----------------|
|
|
111
|
+
| **Contract Compliance Validator** | Ensures implementation matches spec contracts |
|
|
101
112
|
|
|
102
113
|
---
|
|
103
114
|
|
|
104
115
|
## TEMPLATES
|
|
105
116
|
|
|
106
|
-
> ALWAYS use `
|
|
117
|
+
> ALWAYS use `morph-spec template render` to render. NEVER fill placeholders manually.
|
|
107
118
|
|
|
108
119
|
### Placeholders: `{{PLACEHOLDER}}`
|
|
109
120
|
|
|
@@ -112,15 +123,9 @@ project/
|
|
|
112
123
|
| `{{FEATURE_NAME}}` | `scheduled-reports` |
|
|
113
124
|
| `{{FEATURE_NAME_PASCAL}}` | `ScheduledReports` |
|
|
114
125
|
| `{{FEATURE_NAME_CAMEL}}` | `scheduledReports` |
|
|
115
|
-
| `{{STACK}}` | `
|
|
126
|
+
| `{{STACK}}` | `blazor-azure` or `nextjs-supabase` |
|
|
116
127
|
| `{{DATE}}`, `{{AUTHOR}}`, `{{NAMESPACE}}` | Auto from config.json |
|
|
117
128
|
|
|
118
|
-
### Available Templates
|
|
119
|
-
|
|
120
|
-
**MORPH outputs:** proposal, spec, contracts.cs, contracts.ts, decisions, tasks, recap
|
|
121
|
-
|
|
122
|
-
**Code:** service.cs, repository.cs, endpoint.cs
|
|
123
|
-
|
|
124
129
|
---
|
|
125
130
|
|
|
126
131
|
## COMMANDS
|
|
@@ -131,7 +136,7 @@ project/
|
|
|
131
136
|
| `/morph-apply {feature}` | Implement feature (phase 5) |
|
|
132
137
|
| `/morph-status` | Dashboard |
|
|
133
138
|
| `/morph-archive {feature}` | Archive completed feature |
|
|
134
|
-
| `/morph-infra {action}` | Manage
|
|
139
|
+
| `/morph-infra {action}` | Manage infrastructure |
|
|
135
140
|
| `/morph-preflight` | Pre-deploy validation |
|
|
136
141
|
| `/morph-troubleshoot {error}` | Error troubleshooting |
|
|
137
142
|
|
|
@@ -139,11 +144,12 @@ project/
|
|
|
139
144
|
|
|
140
145
|
## REFERENCES
|
|
141
146
|
|
|
142
|
-
- `.morph/
|
|
143
|
-
- `.morph/
|
|
144
|
-
- `.morph/
|
|
145
|
-
- `.morph/
|
|
147
|
+
- `.morph/config/config.json` — Project configuration
|
|
148
|
+
- `.morph/config/agents.json` — Full agent definitions
|
|
149
|
+
- `.morph/standards/` — Coding, architecture, stack-specific standards
|
|
150
|
+
- `.morph/project/context/` — Detection log, project context
|
|
151
|
+
- `.morph/project/standards/inferred.md` — Auto-detected project standards
|
|
146
152
|
|
|
147
153
|
---
|
|
148
154
|
|
|
149
|
-
*MORPH-SPEC by Polymorphism Tech*
|
|
155
|
+
*MORPH-SPEC v4.3.0 by Polymorphism Tech*
|
|
@@ -1,122 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"project": {
|
|
3
|
-
"name": "MyProject",
|
|
4
|
-
"description": "Descrição do projeto",
|
|
5
|
-
"type": "blazor-server",
|
|
6
|
-
"repository": "https://dev.azure.com/org/project/_git/repo"
|
|
7
|
-
},
|
|
8
|
-
"azure": {
|
|
9
|
-
"subscription": "subscription-id",
|
|
10
|
-
"resourceGroup": "rg-myproject-dev",
|
|
11
|
-
"location": "eastus2",
|
|
12
|
-
"resources": {
|
|
13
|
-
"containerApps": {
|
|
14
|
-
"enabled": true,
|
|
15
|
-
"environment": "cae-myproject-dev",
|
|
16
|
-
"minReplicas": 0,
|
|
17
|
-
"maxReplicas": 2
|
|
18
|
-
},
|
|
19
|
-
"sql": {
|
|
20
|
-
"enabled": true,
|
|
21
|
-
"server": "sql-myproject-dev",
|
|
22
|
-
"database": "sqldb-myproject-dev",
|
|
23
|
-
"tier": "Free",
|
|
24
|
-
"maxSizeGB": 32
|
|
25
|
-
},
|
|
26
|
-
"openai": {
|
|
27
|
-
"enabled": true,
|
|
28
|
-
"endpoint": "https://oai-myproject.openai.azure.com/",
|
|
29
|
-
"model": "gpt-4o-mini",
|
|
30
|
-
"maxTokensPerRequest": 4000
|
|
31
|
-
},
|
|
32
|
-
"monitoring": {
|
|
33
|
-
"enabled": true,
|
|
34
|
-
"appInsights": "appi-myproject-dev",
|
|
35
|
-
"logLevel": "Information"
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
},
|
|
39
|
-
"devops": {
|
|
40
|
-
"organization": "https://dev.azure.com/myorg",
|
|
41
|
-
"project": "MyProject",
|
|
42
|
-
"boards": {
|
|
43
|
-
"enabled": true,
|
|
44
|
-
"areaPath": "MyProject\\Features",
|
|
45
|
-
"iterationPath": "MyProject\\Sprint 1"
|
|
46
|
-
},
|
|
47
|
-
"repos": {
|
|
48
|
-
"defaultBranch": "main",
|
|
49
|
-
"featureBranchPrefix": "feature/"
|
|
50
|
-
},
|
|
51
|
-
"pipelines": {
|
|
52
|
-
"buildPipeline": "myproject-ci",
|
|
53
|
-
"releasePipeline": "myproject-cd"
|
|
54
|
-
},
|
|
55
|
-
"wiki": {
|
|
56
|
-
"enabled": true,
|
|
57
|
-
"wikiName": "MyProject.wiki"
|
|
58
|
-
}
|
|
59
|
-
},
|
|
60
|
-
"agents": {
|
|
61
|
-
"core": {
|
|
62
|
-
"standardsArchitect": { "enabled": true },
|
|
63
|
-
"azureArchitect": { "enabled": true },
|
|
64
|
-
"blazorBuilder": { "enabled": true },
|
|
65
|
-
"efModeler": { "enabled": true },
|
|
66
|
-
"msAgentExpert": { "enabled": true }
|
|
67
|
-
},
|
|
68
|
-
"specialists": {
|
|
69
|
-
"hangfireOrchestrator": {
|
|
70
|
-
"enabled": true,
|
|
71
|
-
"autoActivation": ["scheduled", "job", "background", "recurring", "batch", "cron"]
|
|
72
|
-
},
|
|
73
|
-
"uiuxDesigner": {
|
|
74
|
-
"enabled": true,
|
|
75
|
-
"autoActivation": ["wizard", "dashboard", "complex", "drag", "drop", "multi-step"]
|
|
76
|
-
},
|
|
77
|
-
"popmAdvisor": {
|
|
78
|
-
"enabled": true,
|
|
79
|
-
"autoActivation": ["unclear", "requirements", "priority", "ROI", "business", "value"]
|
|
80
|
-
}
|
|
81
|
-
}
|
|
82
|
-
},
|
|
83
|
-
"checkpoints": {
|
|
84
|
-
"afterDesign": true,
|
|
85
|
-
"afterTasks": true,
|
|
86
|
-
"everyNTasks": 3,
|
|
87
|
-
"beforeDeploy": true
|
|
88
|
-
},
|
|
89
|
-
"agentTeams": {
|
|
90
|
-
"enabled": false,
|
|
91
|
-
"experimental": {
|
|
92
|
-
"claudeCodeFlag": "CLAUDE_CODE_EXPERIMENTAL_AGENT_TEAMS",
|
|
93
|
-
"requiresOptIn": true
|
|
94
|
-
},
|
|
95
|
-
"displayMode": "auto",
|
|
96
|
-
"spawnThresholds": {
|
|
97
|
-
"complexity": ["high", "critical"],
|
|
98
|
-
"estimatedFiles": 15,
|
|
99
|
-
"activeAgents": 5,
|
|
100
|
-
"multiDomain": true
|
|
101
|
-
},
|
|
102
|
-
"teamStructure": {
|
|
103
|
-
"maxTeammates": 10,
|
|
104
|
-
"includeValidators": false,
|
|
105
|
-
"validatorsRunInHooks": true
|
|
106
|
-
}
|
|
107
|
-
},
|
|
108
|
-
"context": {
|
|
109
|
-
"enabled": true,
|
|
110
|
-
"autoGenerate": true,
|
|
111
|
-
"templates": {
|
|
112
|
-
"project": "CONTEXT.md",
|
|
113
|
-
"feature": "CONTEXT-{feature}.md"
|
|
114
|
-
},
|
|
115
|
-
"sources": [
|
|
116
|
-
"project.md",
|
|
117
|
-
"state.json",
|
|
118
|
-
"config.json",
|
|
119
|
-
"standards/*.md"
|
|
120
|
-
]
|
|
121
|
-
}
|
|
122
|
-
}
|