diff --git a/.github/actions/build-docs/action.yml b/.github/actions/build-docs/action.yml index 30d8e44e..5ab732f2 100644 --- a/.github/actions/build-docs/action.yml +++ b/.github/actions/build-docs/action.yml @@ -1,17 +1,27 @@ name: Build Documentation description: 'Build Documentation.' +inputs: + workspace_path: + description: 'Path to the workspace.' + required: true runs: using: composite steps: + - name: Setup dotnet build tools + uses: actions/setup-dotnet@v4 + with: + dotnet-version: 6.0 - name: Install docfx shell: bash run: dotnet tool update -g docfx - - name: Run docfx metadata - shell: bash - run: docfx metadata - - name: Run docfx build + + # Note: in the docfx.json file, the 'Configuration' property is set to Debug so that we don't require + # signing to happen just to build docs. + - name: Build docs shell: bash - # Note: in the docfx.json file, the 'Configuration' property is set to Debug so that we don't require - # signing to happen just to build docs. - run: docfx build + run: | + pushd ${{ inputs.workspace_path }} + docfx metadata + docfx build + popd diff --git a/.github/actions/build-release/action.yml b/.github/actions/build-release/action.yml index bf47cbb0..4400e1a5 100644 --- a/.github/actions/build-release/action.yml +++ b/.github/actions/build-release/action.yml @@ -1,5 +1,9 @@ name: Build Action description: 'Dotnet Server SDK Build action.' +inputs: + project_file: + description: 'Path to the project file.' + required: true runs: using: composite @@ -15,4 +19,4 @@ runs: - name: Build shell: bash - run: dotnet build /p:Configuration=Release src/LaunchDarkly.ServerSdk/LaunchDarkly.ServerSdk.csproj + run: dotnet build /p:Configuration=Release ${{ inputs.project_file }} diff --git a/.github/actions/ci/action.yml b/.github/actions/ci/action.yml index 1236f2cd..bbd175d2 100644 --- a/.github/actions/ci/action.yml +++ b/.github/actions/ci/action.yml @@ -1,22 +1,16 @@ name: CI description: Runs CI for the .NET Server SDK inputs: - run_tests: - description: 'If true, run unit tests, otherwise skip them.' + project_file: + description: 'Path to the project file.' + required: true + test_project_file: + description: 'Path to the test project file. If provided, run unit tests, otherwise skip them.' required: false - default: 'true' - run_contract_tests: - description: 'If true, run contract tests, otherwise skip them.' - required: false - default: 'true' aws_role_arn: description: 'The ARN of the role to assume for downloading secrets, used for building docs.' required: false default: '' - token: - description: 'Github token, used for contract tests' - required: false - default: '' runs: using: composite @@ -28,41 +22,23 @@ runs: - name: Restore Dependencies shell: bash - run: dotnet restore src/LaunchDarkly.ServerSdk/LaunchDarkly.ServerSdk.csproj + run: dotnet restore ${{ inputs.project_file }} - name: Build for NetStandard2.0 shell: bash - run: dotnet build -p:Configuration=debug -p:TargetFramework=netstandard2.0 src/LaunchDarkly.ServerSdk/LaunchDarkly.ServerSdk.csproj + run: dotnet build -p:Configuration=debug -p:TargetFramework=netstandard2.0 ${{ inputs.project_file }} - name: Build for Net6 shell: bash - run: dotnet build -p:Configuration=debug -p:TargetFramework=net6.0 src/LaunchDarkly.ServerSdk/LaunchDarkly.ServerSdk.csproj + run: dotnet build -p:Configuration=debug -p:TargetFramework=net6.0 ${{ inputs.project_file }} - name: Build for Net462 shell: bash - run: dotnet build -p:Configuration=debug -p:TargetFramework=net462 src/LaunchDarkly.ServerSdk/LaunchDarkly.ServerSdk.csproj + run: dotnet build -p:Configuration=debug -p:TargetFramework=net462 ${{ inputs.project_file }} - name: Run Unit Tests for Net6 - if: ${{ inputs.run_tests == 'true' }} + if: ${{ inputs.test_project_file != '' }} shell: bash run: | - dotnet restore test/LaunchDarkly.ServerSdk.Tests - dotnet test --framework=net6.0 test/LaunchDarkly.ServerSdk.Tests/LaunchDarkly.ServerSdk.Tests.csproj - - - name: Build Contract Tests - if: ${{ inputs.run_contract_tests == 'true' }} - shell: bash - run: dotnet build /p:Configuration=debug contract-tests/TestService.csproj - - - name: Launch Contract Tests - if: ${{ inputs.run_contract_tests == 'true' }} - id: launch-contract-tests - shell: bash - run: dotnet contract-tests/bin/debug/net6.0/ContractTestService.dll > test-service.log 2>&1 & disown - - - name: Run Contract Tests - if: ${{ inputs.run_contract_tests == 'true' }} - uses: launchdarkly/gh-actions/actions/contract-tests@contract-tests-v1.0.0 - with: - test_service_port: 8000 - token: ${{ inputs.token }} + dotnet restore ${{ inputs.test_project_file }} + dotnet test --framework=net6.0 ${{ inputs.test_project_file }} diff --git a/.github/actions/contract-tests/action.yml b/.github/actions/contract-tests/action.yml new file mode 100644 index 00000000..7750a2cc --- /dev/null +++ b/.github/actions/contract-tests/action.yml @@ -0,0 +1,36 @@ +name: Contract Tests +description: Runs CI for the .NET Server SDK +inputs: + service_project_file: + description: 'Path to the contract test service project file.' + required: true + service_dll_file: + description: 'Path where compiled dll will be found.' + required: true + token: + description: 'Github token, used for contract tests' + required: false + default: '' + +runs: + using: composite + steps: + - name: Setup dotnet build tools + uses: actions/setup-dotnet@v4 + with: + dotnet-version: 6.0 + + - name: Build Contract Tests + shell: bash + run: dotnet build /p:Configuration=debug ${{ inputs.service_project_file }} + + - name: Launch Contract Tests + id: launch-contract-tests + shell: bash + run: dotnet ${{ inputs.service_dll_file }} > test-service.log 2>&1 & disown + + - name: Run Contract Tests + uses: launchdarkly/gh-actions/actions/contract-tests@contract-tests-v1.0.0 + with: + test_service_port: 8000 + token: ${{ inputs.token }} diff --git a/.github/actions/full-release/action.yml b/.github/actions/full-release/action.yml new file mode 100644 index 00000000..31676d9c --- /dev/null +++ b/.github/actions/full-release/action.yml @@ -0,0 +1,71 @@ +name: Build, Test, and Publish +description: 'Execute the full release process for a workspace.' +inputs: + workspace_path: + description: 'Path to the workspace being released.' + required: true + project_file: + description: 'Path to the project file.' + required: true + test_project_file: + description: 'Path to the test project file. If provided, run unit tests, otherwise skip them.' + required: false + build_output_path: + description: 'Build output path.' + required: true + dll_name: + description: 'Build output dll name.' + required: true + dry_run: + description: 'Is this a dry run. If so no package will be published.' + type: boolean + required: true + +runs: + using: composite + steps: + - uses: actions/checkout@v4 + - name: CI check + uses: ./.github/actions/ci + with: + project_file: ${{ inputs.project_file }} + test_project_file: ${{ inputs.test_project_file }} + run_contract_tests: false + + - uses: launchdarkly/gh-actions/actions/release-secrets@release-secrets-v1.1.0 + name: Get secrets + with: + aws_assume_role: ${{ vars.AWS_ROLE_ARN }} + ssm_parameter_pairs: '/production/common/releasing/digicert/host = DIGICERT_HOST, + /production/common/releasing/digicert/api_key = DIGICERT_API_KEY, + /production/common/releasing/digicert/client_cert_file_b64 = DIGICERT_CLIENT_CERT_FILE_B64, + /production/common/releasing/digicert/client_cert_password = DIGICERT_CLIENT_CERT_PASSWORD, + /production/common/releasing/digicert/code_signing_cert_sha1_hash = DIGICERT_CODE_SIGNING_CERT_SHA1_HASH' + s3_path_pairs: 'launchdarkly-releaser/dotnet/LaunchDarkly.snk = LaunchDarkly.snk' + + - name: Release build + uses: ./.github/actions/build-release + with: + project_file: pkgs/sdk/server/src/LaunchDarkly.ServerSdk.csproj + + - name: Sign DLLs + uses: launchdarkly/gh-actions/actions/sign-dlls@sign-dlls-v1.0.0 + with: + build_output_path: ${{ inputs.build_output_path }} + dll_name: ${{ inputs.dll_name }} + + - name: Publish Nupkg + uses: ./.github/actions/publish-package + with: + dry_run: ${{ inputs.dry_run }} + + - name: Build Documentation + uses: ./.github/actions/build-docs + with: + workspace_path: ${{ inputs.workspace_path }} + + - name: Publish Documentation + uses: ./.github/actions/publish-docs + with: + workspace_path: ${{ inputs.workspace_path }} + token: ${{secrets.GITHUB_TOKEN}} diff --git a/.github/actions/publish-docs/action.yml b/.github/actions/publish-docs/action.yml index c5f24ba4..b6896c33 100644 --- a/.github/actions/publish-docs/action.yml +++ b/.github/actions/publish-docs/action.yml @@ -1,6 +1,9 @@ name: Publish Documentation description: 'Publish the documentation to Github pages' inputs: + workspace_path: + description: 'Path to the workspace being released.' + required: true token: description: 'Token to use for publishing.' required: true @@ -11,5 +14,5 @@ runs: - uses: launchdarkly/gh-actions/actions/publish-pages@publish-pages-v1.0.1 name: 'Publish to Github pages' with: - docs_path: docs + docs_path: ${{ inputs.workspace_path }}/docs github_token: ${{ inputs.token }} diff --git a/.github/actions/publish-package/action.yml b/.github/actions/publish-package/action.yml index 150d354e..92ea6b11 100644 --- a/.github/actions/publish-package/action.yml +++ b/.github/actions/publish-package/action.yml @@ -1,6 +1,9 @@ name: Publish Package description: 'Packs DLLs into unsigned Nuget package and publishes to Nuget.' inputs: + project_file: + description: 'Path to the project file.' + required: true dry_run: description: 'Is this a dry run. If so no package will be published.' required: true @@ -12,7 +15,7 @@ runs: shell: bash run: | dotnet restore - dotnet pack --no-build --output nupkgs --configuration Release src/LaunchDarkly.ServerSdk/LaunchDarkly.ServerSdk.csproj + dotnet pack --no-build --output nupkgs --configuration Release ${{ inputs.project_file }} - name: Publish Package if: ${{ inputs.dry_run == 'false' }} diff --git a/.github/workflows/manual-publish.yml b/.github/workflows/manual-publish.yml new file mode 100644 index 00000000..d4b5eba2 --- /dev/null +++ b/.github/workflows/manual-publish.yml @@ -0,0 +1,43 @@ +name: Manual Publish Package +on: + workflow_dispatch: + inputs: + pkg_name: + description: 'The package to publish' + required: true + type: choice + options: + - LaunchDarkly.ServerSdk + - LaunchDarkly.ServerSdk.Telemetry + dry_run: + description: 'Is this a dry run. If so no package will be published.' + type: boolean + required: true + +jobs: + build: + runs-on: ubuntu-latest + permissions: + id-token: write + contents: write + steps: + - uses: ./.github/workflows/full-release.yml + if: ${{ inputs.pkg_name == 'LaunchDarkly.ServerSdk' }} + with: + workspace_path: 'pkgs/sdk/server' + project_file: 'pkgs/sdk/server/src/LaunchDarkly.ServerSdk.csproj' + test_project_file: 'pkgs/sdk/server/test/LaunchDarkly.ServerSdk.Tests.csproj' + build_output_path: 'pkgs/sdk/server/src/bin/Release/' + dll_name: 'LaunchDarkly.ServerSdk.dll' + dry_run: false + +#TODO: consider using inputs.pkg_name in place of those strings in the parameters + - uses: ./.github/workflows/full-release.yml + if: ${{ inputs.pkg_name == 'LaunchDarkly.ServerSdk.Telemetry' }} + with: + workspace_path: 'pkgs/telemetry' + project_file: 'pkgs/telemetry/src/LaunchDarkly.ServerSdk.Telemetry.csproj' + test_project_file: 'pkgs/telemetry/test/LaunchDarkly.ServerSdk.Telemetry.Tests.csproj' + build_output_path: 'pkgs/telemetry/src/bin/Release/' + dll_name: 'LaunchDarkly.ServerSdk.Telemetry.dll' + dry_run: false diff --git a/.github/workflows/publish-docs.yml b/.github/workflows/publish-docs.yml index e92242d8..82368f1f 100644 --- a/.github/workflows/publish-docs.yml +++ b/.github/workflows/publish-docs.yml @@ -1,6 +1,40 @@ on: workflow_dispatch: + inputs: + workspace_path: + description: 'Path to the workspace being released.' + required: true + type: string + project_file: + description: 'Path to the project file.' + required: true + type: string + test_project_file: + description: 'Path to the test project file. If provided, run unit tests, otherwise skip them.' + required: false + type: string + dry_run: + description: 'Is this a dry run. If so no package will be published.' + type: boolean + required: true workflow_call: + inputs: + workspace_path: + description: 'Path to the workspace being released.' + required: true + type: string + project_file: + description: 'Path to the project file.' + required: true + type: string + test_project_file: + description: 'Path to the test project file. If provided, run unit tests, otherwise skip them.' + required: false + type: string + dry_run: + description: 'Is this a dry run. If so no package will be published.' + type: boolean + required: true name: Publish Docs jobs: @@ -14,15 +48,19 @@ jobs: name: Build and Test uses: ./.github/actions/ci with: - run_tests: true - run_contract_tests: false + project_file: pkgs/sdk/server/src/LaunchDarkly.ServerSdk.csproj + test_project_file: pkgs/sdk/server/test/LaunchDarkly.ServerSdk.Tests.csproj + token: ${{ secrets.GITHUB_TOKEN }} - id: build-docs name: Build Documentation uses: ./.github/actions/build-docs + with: + workspace_path: ${{ inputs.workspace_path }} - id: publish name: Publish Documentation uses: ./.github/actions/publish-docs with: + workspace_path: ${{ inputs.workspace_path }} token: ${{secrets.GITHUB_TOKEN}} diff --git a/.github/workflows/release-please.yml b/.github/workflows/release-please.yml index b5f5dc25..6fe3f41a 100644 --- a/.github/workflows/release-please.yml +++ b/.github/workflows/release-please.yml @@ -9,13 +9,9 @@ jobs: release-please: runs-on: ubuntu-latest - permissions: - id-token: write # Needed if using OIDC to get release secrets. - contents: write # Contents and pull-requests are for release-please to make releases. - pull-requests: write - outputs: - releases_created: ${{ steps.release.outputs.releases_created }} + package-sdk-server-released: ${{ steps.release.outputs['pkgs/sdk/server--release_created'] }} + package-sdk-server-telemetry-released: ${{ steps.release.outputs['pkgs/telemetry--release_created'] }} steps: - uses: google-github-actions/release-please-action@v4 @@ -24,15 +20,39 @@ jobs: token: ${{ secrets.GITHUB_TOKEN }} target-branch: ${{ github.ref_name }} - publish-sdk: + release-sdk-server: + runs-on: ubuntu-latest needs: release-please - uses: ./.github/workflows/publish.yml - if: ${{ needs.release-please.outputs.releases_created == 'true' }} - with: - run_tests: true - dry_run: false + permissions: + id-token: write + contents: write + pull-requests: write + if: ${{ needs.release-please.outputs.package-sdk-server-released == 'true'}} + steps: + - uses: ./.github/workflows/full-release.yml + with: + workspace_path: 'pkgs/sdk/server' + project_file: 'pkgs/sdk/server/src/LaunchDarkly.ServerSdk.csproj' + test_project_file: 'pkgs/sdk/server/test/LaunchDarkly.ServerSdk.Tests.csproj' + build_output_path: 'pkgs/sdk/server/src/bin/Release/' + dll_name: 'LaunchDarkly.ServerSdk.dll' + dry_run: false - publish-docs: + release-telemetry: + runs-on: ubuntu-latest needs: release-please - uses: ./.github/workflows/publish-docs.yml - if: ${{ needs.release-please.outputs.releases_created == 'true' }} + permissions: + id-token: write + contents: write + pull-requests: write + if: ${{ needs.release-please.outputs.package-sdk-server-telemetry-released == 'true'}} + steps: + - uses: ./.github/workflows/full-release.yml + with: + workspace_path: 'pkgs/telemetry' + name: 'LaunchDarkly.ServerSdk.Telemetry' + project_file: 'pkgs/telemetry/src/LaunchDarkly.ServerSdk.Telemetry.csproj' + test_project_file: 'pkgs/telemetry/test/LaunchDarkly.ServerSdk.Telemetry.Tests.csproj' + build_output_path: 'pkgs/telemetry/src/bin/Release/' + dll_name: 'LaunchDarkly.ServerSdk.Telemetry.dll' + dry_run: false diff --git a/.github/workflows/sdk-server-ci.yml b/.github/workflows/sdk-server-ci.yml new file mode 100644 index 00000000..155571fd --- /dev/null +++ b/.github/workflows/sdk-server-ci.yml @@ -0,0 +1,38 @@ +name: LaunchDarkly.ServerSdk CI +on: + push: + branches: [main, 'feat/**'] + paths-ignore: + - '**.md' # Do not need to run CI for markdown changes. + pull_request: + branches: [main, 'feat/**'] + paths-ignore: + - '**.md' + +jobs: + build-and-test: + strategy: + matrix: + os: [ubuntu-latest, windows-latest, macos-latest] + fail-fast: false + runs-on: ${{ matrix.os }} + steps: + - uses: actions/checkout@v4 + - uses: ./.github/actions/ci + with: + project_file: pkgs/sdk/server/src/LaunchDarkly.ServerSdk.csproj + test_project_file: pkgs/sdk/server/test/LaunchDarkly.ServerSdk.Tests.csproj + token: ${{ secrets.GITHUB_TOKEN }} + + # Running contract tests on windows is currently cumbersome. + # Once that has been addressed, then running contract tests on windows should be considered. + - uses: ./.github/actions/contract-tests + if: ${{ matrix.os != 'windows-latest' }} + with: + service_project_file: pkgs/sdk/server/contract-tests/TestService.csproj + service_dll_file: pkgs/sdk/server/contract-tests/bin/debug/net6.0/ContractTestService.dll + token: ${{ secrets.GITHUB_TOKEN }} + + - uses: ./.github/actions/build-docs + with: + workspace_path: pkgs/sdk/server diff --git a/.github/workflows/ci.yml b/.github/workflows/telemetry-ci.yml similarity index 51% rename from .github/workflows/ci.yml rename to .github/workflows/telemetry-ci.yml index f9aaf7fd..44845669 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/telemetry-ci.yml @@ -1,4 +1,4 @@ -name: CI +name: LaunchDarkly.ServerSdk.Telemetry CI on: push: branches: [main, 'feat/**'] @@ -20,17 +20,10 @@ jobs: - uses: actions/checkout@v4 - uses: ./.github/actions/ci with: - run_tests: true - # Running contract tests on windows is currently cumbersome. - # Once that has been addressed, then running contract tests on windows should be considered. - run_contract_tests: ${{ matrix.os != 'windows-latest' }} + project_file: pkgs/telemetry/src/LaunchDarkly.ServerSdk.Telemetry.csproj + test_project_file: pkgs/telemetry/test/LaunchDarkly.ServerSdk.Telemetry.Tests.csproj token: ${{ secrets.GITHUB_TOKEN }} - build-docs: - runs-on: ubuntu-latest - permissions: - id-token: write - contents: read - steps: - - uses: actions/checkout@v4 - - uses: ./.github/actions/build-docs + - uses: ./.github/actions/build-docs + with: + workspace_path: pkgs/telemetry diff --git a/.release-please-manifest.json b/.release-please-manifest.json index 8d48393b..0242b38c 100644 --- a/.release-please-manifest.json +++ b/.release-please-manifest.json @@ -1,3 +1,4 @@ { - ".": "8.3.0" + "pkgs/sdk/server": "8.3.0", + "pkgs/telemetry": "0.1.0" } diff --git a/LaunchDarkly.ServerSdk.sln b/LaunchDarkly.ServerSdk.sln index 50e0d23e..03982709 100644 --- a/LaunchDarkly.ServerSdk.sln +++ b/LaunchDarkly.ServerSdk.sln @@ -3,9 +3,21 @@ Microsoft Visual Studio Solution File, Format Version 12.00 # Visual Studio 15 VisualStudioVersion = 15.0.26730.16 MinimumVisualStudioVersion = 10.0.40219.1 -Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "LaunchDarkly.ServerSdk", "src\LaunchDarkly.ServerSdk\LaunchDarkly.ServerSdk.csproj", "{38F73E78-9CEB-4285-B569-034FBD9273D4}" +Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "pkgs", "pkgs", "{2E4B6BA2-5003-4461-B138-BF3F98B89AE7}" EndProject -Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "LaunchDarkly.ServerSdk.Tests", "test\LaunchDarkly.ServerSdk.Tests\LaunchDarkly.ServerSdk.Tests.csproj", "{A8D5ACCF-AADD-4D7C-A768-B98EF014A951}" +Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "sdk", "sdk", "{0A3F3CFA-1CBB-49BD-BCD3-4A53E3D08665}" +EndProject +Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "server", "server", "{FDA973CE-26F2-4745-AF19-0873F170C4CF}" +EndProject +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "LaunchDarkly.ServerSdk", "pkgs\sdk\server\src\LaunchDarkly.ServerSdk.csproj", "{25B32139-B47A-42C9-9277-E65FAD6A448A}" +EndProject +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "LaunchDarkly.ServerSdk.Tests", "pkgs\sdk\server\test\LaunchDarkly.ServerSdk.Tests.csproj", "{978CC958-FE5A-43A3-A228-03C2DBC94117}" +EndProject +Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "telemetry", "telemetry", "{7A984A5D-0C83-42FA-8BF7-DCA2441F62DA}" +EndProject +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "LaunchDarkly.ServerSdk.Telemetry", "pkgs\telemetry\src\LaunchDarkly.ServerSdk.Telemetry.csproj", "{35014C04-26CE-43B0-933D-35D80CF0E6B8}" +EndProject +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "LaunchDarkly.ServerSdk.Telemetry.Tests", "pkgs\telemetry\test\LaunchDarkly.ServerSdk.Telemetry.Tests.csproj", "{71299584-BF0D-48A4-B2E1-D6292036D48D}" EndProject Global GlobalSection(SolutionConfigurationPlatforms) = preSolution @@ -13,14 +25,22 @@ Global Release|Any CPU = Release|Any CPU EndGlobalSection GlobalSection(ProjectConfigurationPlatforms) = postSolution - {38F73E78-9CEB-4285-B569-034FBD9273D4}.Debug|Any CPU.ActiveCfg = Debug|Any CPU - {38F73E78-9CEB-4285-B569-034FBD9273D4}.Debug|Any CPU.Build.0 = Debug|Any CPU - {38F73E78-9CEB-4285-B569-034FBD9273D4}.Release|Any CPU.ActiveCfg = Release|Any CPU - {38F73E78-9CEB-4285-B569-034FBD9273D4}.Release|Any CPU.Build.0 = Release|Any CPU - {A8D5ACCF-AADD-4D7C-A768-B98EF014A951}.Debug|Any CPU.ActiveCfg = Debug|Any CPU - {A8D5ACCF-AADD-4D7C-A768-B98EF014A951}.Debug|Any CPU.Build.0 = Debug|Any CPU - {A8D5ACCF-AADD-4D7C-A768-B98EF014A951}.Release|Any CPU.ActiveCfg = Release|Any CPU - {A8D5ACCF-AADD-4D7C-A768-B98EF014A951}.Release|Any CPU.Build.0 = Release|Any CPU + {25B32139-B47A-42C9-9277-E65FAD6A448A}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {25B32139-B47A-42C9-9277-E65FAD6A448A}.Debug|Any CPU.Build.0 = Debug|Any CPU + {25B32139-B47A-42C9-9277-E65FAD6A448A}.Release|Any CPU.ActiveCfg = Release|Any CPU + {25B32139-B47A-42C9-9277-E65FAD6A448A}.Release|Any CPU.Build.0 = Release|Any CPU + {978CC958-FE5A-43A3-A228-03C2DBC94117}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {978CC958-FE5A-43A3-A228-03C2DBC94117}.Debug|Any CPU.Build.0 = Debug|Any CPU + {978CC958-FE5A-43A3-A228-03C2DBC94117}.Release|Any CPU.ActiveCfg = Release|Any CPU + {978CC958-FE5A-43A3-A228-03C2DBC94117}.Release|Any CPU.Build.0 = Release|Any CPU + {35014C04-26CE-43B0-933D-35D80CF0E6B8}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {35014C04-26CE-43B0-933D-35D80CF0E6B8}.Debug|Any CPU.Build.0 = Debug|Any CPU + {35014C04-26CE-43B0-933D-35D80CF0E6B8}.Release|Any CPU.ActiveCfg = Release|Any CPU + {35014C04-26CE-43B0-933D-35D80CF0E6B8}.Release|Any CPU.Build.0 = Release|Any CPU + {71299584-BF0D-48A4-B2E1-D6292036D48D}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {71299584-BF0D-48A4-B2E1-D6292036D48D}.Debug|Any CPU.Build.0 = Debug|Any CPU + {71299584-BF0D-48A4-B2E1-D6292036D48D}.Release|Any CPU.ActiveCfg = Release|Any CPU + {71299584-BF0D-48A4-B2E1-D6292036D48D}.Release|Any CPU.Build.0 = Release|Any CPU EndGlobalSection GlobalSection(SolutionProperties) = preSolution HideSolutionNode = FALSE @@ -28,4 +48,13 @@ Global GlobalSection(ExtensibilityGlobals) = postSolution SolutionGuid = {D7F58FE1-D8E9-46EB-AE7F-4B5A388418AC} EndGlobalSection + GlobalSection(NestedProjects) = preSolution + {0A3F3CFA-1CBB-49BD-BCD3-4A53E3D08665} = {2E4B6BA2-5003-4461-B138-BF3F98B89AE7} + {FDA973CE-26F2-4745-AF19-0873F170C4CF} = {0A3F3CFA-1CBB-49BD-BCD3-4A53E3D08665} + {25B32139-B47A-42C9-9277-E65FAD6A448A} = {FDA973CE-26F2-4745-AF19-0873F170C4CF} + {978CC958-FE5A-43A3-A228-03C2DBC94117} = {FDA973CE-26F2-4745-AF19-0873F170C4CF} + {7A984A5D-0C83-42FA-8BF7-DCA2441F62DA} = {2E4B6BA2-5003-4461-B138-BF3F98B89AE7} + {35014C04-26CE-43B0-933D-35D80CF0E6B8} = {7A984A5D-0C83-42FA-8BF7-DCA2441F62DA} + {71299584-BF0D-48A4-B2E1-D6292036D48D} = {7A984A5D-0C83-42FA-8BF7-DCA2441F62DA} + EndGlobalSection EndGlobal diff --git a/contract-tests/BigSegmentStoreFixture.cs b/pkgs/sdk/server/contract-tests/BigSegmentStoreFixture.cs similarity index 100% rename from contract-tests/BigSegmentStoreFixture.cs rename to pkgs/sdk/server/contract-tests/BigSegmentStoreFixture.cs diff --git a/contract-tests/CallbackRepresentations.cs b/pkgs/sdk/server/contract-tests/CallbackRepresentations.cs similarity index 100% rename from contract-tests/CallbackRepresentations.cs rename to pkgs/sdk/server/contract-tests/CallbackRepresentations.cs diff --git a/contract-tests/CallbackService.cs b/pkgs/sdk/server/contract-tests/CallbackService.cs similarity index 100% rename from contract-tests/CallbackService.cs rename to pkgs/sdk/server/contract-tests/CallbackService.cs diff --git a/contract-tests/README.md b/pkgs/sdk/server/contract-tests/README.md similarity index 100% rename from contract-tests/README.md rename to pkgs/sdk/server/contract-tests/README.md diff --git a/contract-tests/Representations.cs b/pkgs/sdk/server/contract-tests/Representations.cs similarity index 100% rename from contract-tests/Representations.cs rename to pkgs/sdk/server/contract-tests/Representations.cs diff --git a/contract-tests/SdkClientEntity.cs b/pkgs/sdk/server/contract-tests/SdkClientEntity.cs similarity index 100% rename from contract-tests/SdkClientEntity.cs rename to pkgs/sdk/server/contract-tests/SdkClientEntity.cs diff --git a/contract-tests/TestHook.cs b/pkgs/sdk/server/contract-tests/TestHook.cs similarity index 100% rename from contract-tests/TestHook.cs rename to pkgs/sdk/server/contract-tests/TestHook.cs diff --git a/contract-tests/TestService.cs b/pkgs/sdk/server/contract-tests/TestService.cs similarity index 100% rename from contract-tests/TestService.cs rename to pkgs/sdk/server/contract-tests/TestService.cs diff --git a/contract-tests/TestService.csproj b/pkgs/sdk/server/contract-tests/TestService.csproj similarity index 91% rename from contract-tests/TestService.csproj rename to pkgs/sdk/server/contract-tests/TestService.csproj index fa0b556c..ee910a50 100644 --- a/contract-tests/TestService.csproj +++ b/pkgs/sdk/server/contract-tests/TestService.csproj @@ -20,7 +20,7 @@ - + diff --git a/contract-tests/TestService.sln b/pkgs/sdk/server/contract-tests/TestService.sln similarity index 100% rename from contract-tests/TestService.sln rename to pkgs/sdk/server/contract-tests/TestService.sln diff --git a/pkgs/sdk/server/docfx.json b/pkgs/sdk/server/docfx.json new file mode 100644 index 00000000..cc59d5c3 --- /dev/null +++ b/pkgs/sdk/server/docfx.json @@ -0,0 +1,48 @@ +{ + "metadata": [ + { + "src": [ + { + "src": "./src", + "files": [ + "**/*.csproj", + "**/bin/**/**LaunchDarkly**.dll" + ] + } + ], + "dest": "./api", + "properties" : { + "Configuration": "Debug" + }, + } + ], + "build": { + "content": [ + { + "files": [ + "**/*.{md,yml}" + ], + "exclude": [ + "docs/**" + ] + } + ], + "resource": [ + { + "files": [ + "images/**" + ] + } + ], + "output": "docs", + "template": [ + "default" + ], + "globalMetadata": { + "_appName": "LaunchDarkly Dotnet Server SDK", + "_appTitle": "LaunchDarkly Dotnet Server SDK", + "_enableSearch": true, + "pdf": false + } + } +} diff --git a/docs-src/README.md b/pkgs/sdk/server/docs-src/README.md similarity index 100% rename from docs-src/README.md rename to pkgs/sdk/server/docs-src/README.md diff --git a/docs-src/namespaces/LaunchDarkly.Sdk.Json.md b/pkgs/sdk/server/docs-src/namespaces/LaunchDarkly.Sdk.Json.md similarity index 100% rename from docs-src/namespaces/LaunchDarkly.Sdk.Json.md rename to pkgs/sdk/server/docs-src/namespaces/LaunchDarkly.Sdk.Json.md diff --git a/docs-src/namespaces/LaunchDarkly.Sdk.Server.Integrations.md b/pkgs/sdk/server/docs-src/namespaces/LaunchDarkly.Sdk.Server.Integrations.md similarity index 100% rename from docs-src/namespaces/LaunchDarkly.Sdk.Server.Integrations.md rename to pkgs/sdk/server/docs-src/namespaces/LaunchDarkly.Sdk.Server.Integrations.md diff --git a/docs-src/namespaces/LaunchDarkly.Sdk.Server.Interfaces.md b/pkgs/sdk/server/docs-src/namespaces/LaunchDarkly.Sdk.Server.Interfaces.md similarity index 100% rename from docs-src/namespaces/LaunchDarkly.Sdk.Server.Interfaces.md rename to pkgs/sdk/server/docs-src/namespaces/LaunchDarkly.Sdk.Server.Interfaces.md diff --git a/docs-src/namespaces/LaunchDarkly.Sdk.Server.Subsystems.md b/pkgs/sdk/server/docs-src/namespaces/LaunchDarkly.Sdk.Server.Subsystems.md similarity index 100% rename from docs-src/namespaces/LaunchDarkly.Sdk.Server.Subsystems.md rename to pkgs/sdk/server/docs-src/namespaces/LaunchDarkly.Sdk.Server.Subsystems.md diff --git a/docs-src/namespaces/LaunchDarkly.Sdk.Server.md b/pkgs/sdk/server/docs-src/namespaces/LaunchDarkly.Sdk.Server.md similarity index 100% rename from docs-src/namespaces/LaunchDarkly.Sdk.Server.md rename to pkgs/sdk/server/docs-src/namespaces/LaunchDarkly.Sdk.Server.md diff --git a/docs-src/namespaces/LaunchDarkly.Sdk.md b/pkgs/sdk/server/docs-src/namespaces/LaunchDarkly.Sdk.md similarity index 100% rename from docs-src/namespaces/LaunchDarkly.Sdk.md rename to pkgs/sdk/server/docs-src/namespaces/LaunchDarkly.Sdk.md diff --git a/src/LaunchDarkly.ServerSdk/Components.cs b/pkgs/sdk/server/src/Components.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Components.cs rename to pkgs/sdk/server/src/Components.cs diff --git a/src/LaunchDarkly.ServerSdk/Configuration.cs b/pkgs/sdk/server/src/Configuration.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Configuration.cs rename to pkgs/sdk/server/src/Configuration.cs diff --git a/src/LaunchDarkly.ServerSdk/ConfigurationBuilder.cs b/pkgs/sdk/server/src/ConfigurationBuilder.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/ConfigurationBuilder.cs rename to pkgs/sdk/server/src/ConfigurationBuilder.cs diff --git a/src/LaunchDarkly.ServerSdk/DataModel.cs b/pkgs/sdk/server/src/DataModel.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/DataModel.cs rename to pkgs/sdk/server/src/DataModel.cs diff --git a/src/LaunchDarkly.ServerSdk/FeatureFlagsState.cs b/pkgs/sdk/server/src/FeatureFlagsState.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/FeatureFlagsState.cs rename to pkgs/sdk/server/src/FeatureFlagsState.cs diff --git a/src/LaunchDarkly.ServerSdk/FlagsStateOption.cs b/pkgs/sdk/server/src/FlagsStateOption.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/FlagsStateOption.cs rename to pkgs/sdk/server/src/FlagsStateOption.cs diff --git a/src/LaunchDarkly.ServerSdk/Hooks/EvaluationSeriesContext.cs b/pkgs/sdk/server/src/Hooks/EvaluationSeriesContext.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Hooks/EvaluationSeriesContext.cs rename to pkgs/sdk/server/src/Hooks/EvaluationSeriesContext.cs diff --git a/src/LaunchDarkly.ServerSdk/Hooks/Hook.cs b/pkgs/sdk/server/src/Hooks/Hook.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Hooks/Hook.cs rename to pkgs/sdk/server/src/Hooks/Hook.cs diff --git a/src/LaunchDarkly.ServerSdk/Hooks/Method.cs b/pkgs/sdk/server/src/Hooks/Method.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Hooks/Method.cs rename to pkgs/sdk/server/src/Hooks/Method.cs diff --git a/src/LaunchDarkly.ServerSdk/Hooks/SeriesDataBuilder.cs b/pkgs/sdk/server/src/Hooks/SeriesDataBuilder.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Hooks/SeriesDataBuilder.cs rename to pkgs/sdk/server/src/Hooks/SeriesDataBuilder.cs diff --git a/src/LaunchDarkly.ServerSdk/ILdClientExtensions.cs b/pkgs/sdk/server/src/ILdClientExtensions.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/ILdClientExtensions.cs rename to pkgs/sdk/server/src/ILdClientExtensions.cs diff --git a/src/LaunchDarkly.ServerSdk/Integrations/BigSegmentsConfigurationBuilder.cs b/pkgs/sdk/server/src/Integrations/BigSegmentsConfigurationBuilder.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Integrations/BigSegmentsConfigurationBuilder.cs rename to pkgs/sdk/server/src/Integrations/BigSegmentsConfigurationBuilder.cs diff --git a/src/LaunchDarkly.ServerSdk/Integrations/EventProcessorBuilder.cs b/pkgs/sdk/server/src/Integrations/EventProcessorBuilder.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Integrations/EventProcessorBuilder.cs rename to pkgs/sdk/server/src/Integrations/EventProcessorBuilder.cs diff --git a/src/LaunchDarkly.ServerSdk/Integrations/FileData.cs b/pkgs/sdk/server/src/Integrations/FileData.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Integrations/FileData.cs rename to pkgs/sdk/server/src/Integrations/FileData.cs diff --git a/src/LaunchDarkly.ServerSdk/Integrations/FileDataSourceBuilder.cs b/pkgs/sdk/server/src/Integrations/FileDataSourceBuilder.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Integrations/FileDataSourceBuilder.cs rename to pkgs/sdk/server/src/Integrations/FileDataSourceBuilder.cs diff --git a/src/LaunchDarkly.ServerSdk/Integrations/FileDataTypes.cs b/pkgs/sdk/server/src/Integrations/FileDataTypes.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Integrations/FileDataTypes.cs rename to pkgs/sdk/server/src/Integrations/FileDataTypes.cs diff --git a/src/LaunchDarkly.ServerSdk/Integrations/HookConfigurationBuilder.cs b/pkgs/sdk/server/src/Integrations/HookConfigurationBuilder.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Integrations/HookConfigurationBuilder.cs rename to pkgs/sdk/server/src/Integrations/HookConfigurationBuilder.cs diff --git a/src/LaunchDarkly.ServerSdk/Integrations/HttpConfigurationBuilder.cs b/pkgs/sdk/server/src/Integrations/HttpConfigurationBuilder.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Integrations/HttpConfigurationBuilder.cs rename to pkgs/sdk/server/src/Integrations/HttpConfigurationBuilder.cs diff --git a/src/LaunchDarkly.ServerSdk/Integrations/LoggingConfigurationBuilder.cs b/pkgs/sdk/server/src/Integrations/LoggingConfigurationBuilder.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Integrations/LoggingConfigurationBuilder.cs rename to pkgs/sdk/server/src/Integrations/LoggingConfigurationBuilder.cs diff --git a/src/LaunchDarkly.ServerSdk/Integrations/PersistentDataStoreBuilder.cs b/pkgs/sdk/server/src/Integrations/PersistentDataStoreBuilder.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Integrations/PersistentDataStoreBuilder.cs rename to pkgs/sdk/server/src/Integrations/PersistentDataStoreBuilder.cs diff --git a/src/LaunchDarkly.ServerSdk/Integrations/PollingDataSourceBuilder.cs b/pkgs/sdk/server/src/Integrations/PollingDataSourceBuilder.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Integrations/PollingDataSourceBuilder.cs rename to pkgs/sdk/server/src/Integrations/PollingDataSourceBuilder.cs diff --git a/src/LaunchDarkly.ServerSdk/Integrations/ServiceEndpointsBuilder.cs b/pkgs/sdk/server/src/Integrations/ServiceEndpointsBuilder.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Integrations/ServiceEndpointsBuilder.cs rename to pkgs/sdk/server/src/Integrations/ServiceEndpointsBuilder.cs diff --git a/src/LaunchDarkly.ServerSdk/Integrations/StreamingDataSourceBuilder.cs b/pkgs/sdk/server/src/Integrations/StreamingDataSourceBuilder.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Integrations/StreamingDataSourceBuilder.cs rename to pkgs/sdk/server/src/Integrations/StreamingDataSourceBuilder.cs diff --git a/src/LaunchDarkly.ServerSdk/Integrations/TestData.cs b/pkgs/sdk/server/src/Integrations/TestData.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Integrations/TestData.cs rename to pkgs/sdk/server/src/Integrations/TestData.cs diff --git a/src/LaunchDarkly.ServerSdk/Integrations/WrapperInfoBuilder.cs b/pkgs/sdk/server/src/Integrations/WrapperInfoBuilder.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Integrations/WrapperInfoBuilder.cs rename to pkgs/sdk/server/src/Integrations/WrapperInfoBuilder.cs diff --git a/src/LaunchDarkly.ServerSdk/Interfaces/BigSegmentStoreStatus.cs b/pkgs/sdk/server/src/Interfaces/BigSegmentStoreStatus.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Interfaces/BigSegmentStoreStatus.cs rename to pkgs/sdk/server/src/Interfaces/BigSegmentStoreStatus.cs diff --git a/src/LaunchDarkly.ServerSdk/Interfaces/DataSourceStatus.cs b/pkgs/sdk/server/src/Interfaces/DataSourceStatus.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Interfaces/DataSourceStatus.cs rename to pkgs/sdk/server/src/Interfaces/DataSourceStatus.cs diff --git a/src/LaunchDarkly.ServerSdk/Interfaces/DataStoreStatus.cs b/pkgs/sdk/server/src/Interfaces/DataStoreStatus.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Interfaces/DataStoreStatus.cs rename to pkgs/sdk/server/src/Interfaces/DataStoreStatus.cs diff --git a/src/LaunchDarkly.ServerSdk/Interfaces/IBigSegmentStoreStatusProvider.cs b/pkgs/sdk/server/src/Interfaces/IBigSegmentStoreStatusProvider.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Interfaces/IBigSegmentStoreStatusProvider.cs rename to pkgs/sdk/server/src/Interfaces/IBigSegmentStoreStatusProvider.cs diff --git a/src/LaunchDarkly.ServerSdk/Interfaces/IDataSourceStatusProvider.cs b/pkgs/sdk/server/src/Interfaces/IDataSourceStatusProvider.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Interfaces/IDataSourceStatusProvider.cs rename to pkgs/sdk/server/src/Interfaces/IDataSourceStatusProvider.cs diff --git a/src/LaunchDarkly.ServerSdk/Interfaces/IDataStoreStatusProvider.cs b/pkgs/sdk/server/src/Interfaces/IDataStoreStatusProvider.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Interfaces/IDataStoreStatusProvider.cs rename to pkgs/sdk/server/src/Interfaces/IDataStoreStatusProvider.cs diff --git a/src/LaunchDarkly.ServerSdk/Interfaces/IFlagTracker.cs b/pkgs/sdk/server/src/Interfaces/IFlagTracker.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Interfaces/IFlagTracker.cs rename to pkgs/sdk/server/src/Interfaces/IFlagTracker.cs diff --git a/src/LaunchDarkly.ServerSdk/Interfaces/ILdClient.cs b/pkgs/sdk/server/src/Interfaces/ILdClient.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Interfaces/ILdClient.cs rename to pkgs/sdk/server/src/Interfaces/ILdClient.cs diff --git a/src/LaunchDarkly.ServerSdk/Interfaces/ServiceEndpoints.cs b/pkgs/sdk/server/src/Interfaces/ServiceEndpoints.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Interfaces/ServiceEndpoints.cs rename to pkgs/sdk/server/src/Interfaces/ServiceEndpoints.cs diff --git a/src/LaunchDarkly.ServerSdk/Interfaces/WrapperInfo.cs b/pkgs/sdk/server/src/Interfaces/WrapperInfo.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Interfaces/WrapperInfo.cs rename to pkgs/sdk/server/src/Interfaces/WrapperInfo.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/BigSegments/BigSegmentStoreStatusProviderImpl.cs b/pkgs/sdk/server/src/Internal/BigSegments/BigSegmentStoreStatusProviderImpl.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/BigSegments/BigSegmentStoreStatusProviderImpl.cs rename to pkgs/sdk/server/src/Internal/BigSegments/BigSegmentStoreStatusProviderImpl.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/BigSegments/BigSegmentStoreWrapper.cs b/pkgs/sdk/server/src/Internal/BigSegments/BigSegmentStoreWrapper.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/BigSegments/BigSegmentStoreWrapper.cs rename to pkgs/sdk/server/src/Internal/BigSegments/BigSegmentStoreWrapper.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/BigSegments/BigSegmentsInternalTypes.cs b/pkgs/sdk/server/src/Internal/BigSegments/BigSegmentsInternalTypes.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/BigSegments/BigSegmentsInternalTypes.cs rename to pkgs/sdk/server/src/Internal/BigSegments/BigSegmentsInternalTypes.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/BigSegments/MembershipBuilder.cs b/pkgs/sdk/server/src/Internal/BigSegments/MembershipBuilder.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/BigSegments/MembershipBuilder.cs rename to pkgs/sdk/server/src/Internal/BigSegments/MembershipBuilder.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/BigSegments/NamespaceReadme.md b/pkgs/sdk/server/src/Internal/BigSegments/NamespaceReadme.md similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/BigSegments/NamespaceReadme.md rename to pkgs/sdk/server/src/Internal/BigSegments/NamespaceReadme.md diff --git a/src/LaunchDarkly.ServerSdk/Internal/ComponentsImpl.cs b/pkgs/sdk/server/src/Internal/ComponentsImpl.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/ComponentsImpl.cs rename to pkgs/sdk/server/src/Internal/ComponentsImpl.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/DataModelDependencies.cs b/pkgs/sdk/server/src/Internal/DataModelDependencies.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/DataModelDependencies.cs rename to pkgs/sdk/server/src/Internal/DataModelDependencies.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/DataSources/DataSourceOutageTracker.cs b/pkgs/sdk/server/src/Internal/DataSources/DataSourceOutageTracker.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/DataSources/DataSourceOutageTracker.cs rename to pkgs/sdk/server/src/Internal/DataSources/DataSourceOutageTracker.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/DataSources/DataSourceStatusProviderImpl.cs b/pkgs/sdk/server/src/Internal/DataSources/DataSourceStatusProviderImpl.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/DataSources/DataSourceStatusProviderImpl.cs rename to pkgs/sdk/server/src/Internal/DataSources/DataSourceStatusProviderImpl.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/DataSources/DataSourceUpdatesImpl.cs b/pkgs/sdk/server/src/Internal/DataSources/DataSourceUpdatesImpl.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/DataSources/DataSourceUpdatesImpl.cs rename to pkgs/sdk/server/src/Internal/DataSources/DataSourceUpdatesImpl.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/DataSources/FeatureRequestor.cs b/pkgs/sdk/server/src/Internal/DataSources/FeatureRequestor.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/DataSources/FeatureRequestor.cs rename to pkgs/sdk/server/src/Internal/DataSources/FeatureRequestor.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/DataSources/FileDataSource.cs b/pkgs/sdk/server/src/Internal/DataSources/FileDataSource.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/DataSources/FileDataSource.cs rename to pkgs/sdk/server/src/Internal/DataSources/FileDataSource.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/DataSources/FlagFileParser.cs b/pkgs/sdk/server/src/Internal/DataSources/FlagFileParser.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/DataSources/FlagFileParser.cs rename to pkgs/sdk/server/src/Internal/DataSources/FlagFileParser.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/DataSources/FlagFileReader.cs b/pkgs/sdk/server/src/Internal/DataSources/FlagFileReader.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/DataSources/FlagFileReader.cs rename to pkgs/sdk/server/src/Internal/DataSources/FlagFileReader.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/DataSources/IFeatureRequestor.cs b/pkgs/sdk/server/src/Internal/DataSources/IFeatureRequestor.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/DataSources/IFeatureRequestor.cs rename to pkgs/sdk/server/src/Internal/DataSources/IFeatureRequestor.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/DataSources/NamespaceReadme.md b/pkgs/sdk/server/src/Internal/DataSources/NamespaceReadme.md similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/DataSources/NamespaceReadme.md rename to pkgs/sdk/server/src/Internal/DataSources/NamespaceReadme.md diff --git a/src/LaunchDarkly.ServerSdk/Internal/DataSources/PollingDataSource.cs b/pkgs/sdk/server/src/Internal/DataSources/PollingDataSource.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/DataSources/PollingDataSource.cs rename to pkgs/sdk/server/src/Internal/DataSources/PollingDataSource.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/DataSources/StreamProcessorEvents.cs b/pkgs/sdk/server/src/Internal/DataSources/StreamProcessorEvents.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/DataSources/StreamProcessorEvents.cs rename to pkgs/sdk/server/src/Internal/DataSources/StreamProcessorEvents.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/DataSources/StreamingDataSource.cs b/pkgs/sdk/server/src/Internal/DataSources/StreamingDataSource.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/DataSources/StreamingDataSource.cs rename to pkgs/sdk/server/src/Internal/DataSources/StreamingDataSource.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/DataStores/DataStoreCacheConfig.cs b/pkgs/sdk/server/src/Internal/DataStores/DataStoreCacheConfig.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/DataStores/DataStoreCacheConfig.cs rename to pkgs/sdk/server/src/Internal/DataStores/DataStoreCacheConfig.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/DataStores/DataStoreSorter.cs b/pkgs/sdk/server/src/Internal/DataStores/DataStoreSorter.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/DataStores/DataStoreSorter.cs rename to pkgs/sdk/server/src/Internal/DataStores/DataStoreSorter.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/DataStores/DataStoreStatusProviderImpl.cs b/pkgs/sdk/server/src/Internal/DataStores/DataStoreStatusProviderImpl.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/DataStores/DataStoreStatusProviderImpl.cs rename to pkgs/sdk/server/src/Internal/DataStores/DataStoreStatusProviderImpl.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/DataStores/DataStoreUpdatesImpl.cs b/pkgs/sdk/server/src/Internal/DataStores/DataStoreUpdatesImpl.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/DataStores/DataStoreUpdatesImpl.cs rename to pkgs/sdk/server/src/Internal/DataStores/DataStoreUpdatesImpl.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/DataStores/InMemoryDataStore.cs b/pkgs/sdk/server/src/Internal/DataStores/InMemoryDataStore.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/DataStores/InMemoryDataStore.cs rename to pkgs/sdk/server/src/Internal/DataStores/InMemoryDataStore.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/DataStores/NamespaceReadme.md b/pkgs/sdk/server/src/Internal/DataStores/NamespaceReadme.md similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/DataStores/NamespaceReadme.md rename to pkgs/sdk/server/src/Internal/DataStores/NamespaceReadme.md diff --git a/src/LaunchDarkly.ServerSdk/Internal/DataStores/PersistentDataStoreStatusManager.cs b/pkgs/sdk/server/src/Internal/DataStores/PersistentDataStoreStatusManager.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/DataStores/PersistentDataStoreStatusManager.cs rename to pkgs/sdk/server/src/Internal/DataStores/PersistentDataStoreStatusManager.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/DataStores/PersistentStoreAsyncAdapter.cs b/pkgs/sdk/server/src/Internal/DataStores/PersistentStoreAsyncAdapter.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/DataStores/PersistentStoreAsyncAdapter.cs rename to pkgs/sdk/server/src/Internal/DataStores/PersistentStoreAsyncAdapter.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/DataStores/PersistentStoreWrapper.cs b/pkgs/sdk/server/src/Internal/DataStores/PersistentStoreWrapper.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/DataStores/PersistentStoreWrapper.cs rename to pkgs/sdk/server/src/Internal/DataStores/PersistentStoreWrapper.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/Evaluation/Bucketing.cs b/pkgs/sdk/server/src/Internal/Evaluation/Bucketing.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/Evaluation/Bucketing.cs rename to pkgs/sdk/server/src/Internal/Evaluation/Bucketing.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/Evaluation/Evaluator.cs b/pkgs/sdk/server/src/Internal/Evaluation/Evaluator.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/Evaluation/Evaluator.cs rename to pkgs/sdk/server/src/Internal/Evaluation/Evaluator.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/Evaluation/EvaluatorClause.cs b/pkgs/sdk/server/src/Internal/Evaluation/EvaluatorClause.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/Evaluation/EvaluatorClause.cs rename to pkgs/sdk/server/src/Internal/Evaluation/EvaluatorClause.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/Evaluation/EvaluatorSegment.cs b/pkgs/sdk/server/src/Internal/Evaluation/EvaluatorSegment.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/Evaluation/EvaluatorSegment.cs rename to pkgs/sdk/server/src/Internal/Evaluation/EvaluatorSegment.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/Evaluation/EvaluatorTarget.cs b/pkgs/sdk/server/src/Internal/Evaluation/EvaluatorTarget.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/Evaluation/EvaluatorTarget.cs rename to pkgs/sdk/server/src/Internal/Evaluation/EvaluatorTarget.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/Evaluation/EvaluatorTypes.cs b/pkgs/sdk/server/src/Internal/Evaluation/EvaluatorTypes.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/Evaluation/EvaluatorTypes.cs rename to pkgs/sdk/server/src/Internal/Evaluation/EvaluatorTypes.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/Evaluation/NamespaceReadme.md b/pkgs/sdk/server/src/Internal/Evaluation/NamespaceReadme.md similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/Evaluation/NamespaceReadme.md rename to pkgs/sdk/server/src/Internal/Evaluation/NamespaceReadme.md diff --git a/src/LaunchDarkly.ServerSdk/Internal/Events/DefaultContextDeduplicator.cs b/pkgs/sdk/server/src/Internal/Events/DefaultContextDeduplicator.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/Events/DefaultContextDeduplicator.cs rename to pkgs/sdk/server/src/Internal/Events/DefaultContextDeduplicator.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/Events/DefaultEventProcessorWrapper.cs b/pkgs/sdk/server/src/Internal/Events/DefaultEventProcessorWrapper.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/Events/DefaultEventProcessorWrapper.cs rename to pkgs/sdk/server/src/Internal/Events/DefaultEventProcessorWrapper.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/Events/EventFactory.cs b/pkgs/sdk/server/src/Internal/Events/EventFactory.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/Events/EventFactory.cs rename to pkgs/sdk/server/src/Internal/Events/EventFactory.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/Events/NamespaceReadme.md b/pkgs/sdk/server/src/Internal/Events/NamespaceReadme.md similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/Events/NamespaceReadme.md rename to pkgs/sdk/server/src/Internal/Events/NamespaceReadme.md diff --git a/src/LaunchDarkly.ServerSdk/Internal/Events/ServerDiagnosticStore.cs b/pkgs/sdk/server/src/Internal/Events/ServerDiagnosticStore.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/Events/ServerDiagnosticStore.cs rename to pkgs/sdk/server/src/Internal/Events/ServerDiagnosticStore.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/FlagTrackerImpl.cs b/pkgs/sdk/server/src/Internal/FlagTrackerImpl.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/FlagTrackerImpl.cs rename to pkgs/sdk/server/src/Internal/FlagTrackerImpl.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/Hooks/Executor/Executor.cs b/pkgs/sdk/server/src/Internal/Hooks/Executor/Executor.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/Hooks/Executor/Executor.cs rename to pkgs/sdk/server/src/Internal/Hooks/Executor/Executor.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/Hooks/Executor/NoopExecutor.cs b/pkgs/sdk/server/src/Internal/Hooks/Executor/NoopExecutor.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/Hooks/Executor/NoopExecutor.cs rename to pkgs/sdk/server/src/Internal/Hooks/Executor/NoopExecutor.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/Hooks/Interfaces/IHookExecutor.cs b/pkgs/sdk/server/src/Internal/Hooks/Interfaces/IHookExecutor.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/Hooks/Interfaces/IHookExecutor.cs rename to pkgs/sdk/server/src/Internal/Hooks/Interfaces/IHookExecutor.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/Hooks/Interfaces/IStageExecutor.cs b/pkgs/sdk/server/src/Internal/Hooks/Interfaces/IStageExecutor.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/Hooks/Interfaces/IStageExecutor.cs rename to pkgs/sdk/server/src/Internal/Hooks/Interfaces/IStageExecutor.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/Hooks/Series/EvaluationSeries.cs b/pkgs/sdk/server/src/Internal/Hooks/Series/EvaluationSeries.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/Hooks/Series/EvaluationSeries.cs rename to pkgs/sdk/server/src/Internal/Hooks/Series/EvaluationSeries.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/LRUCacheSet.cs b/pkgs/sdk/server/src/Internal/LRUCacheSet.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/LRUCacheSet.cs rename to pkgs/sdk/server/src/Internal/LRUCacheSet.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/LogNames.cs b/pkgs/sdk/server/src/Internal/LogNames.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/LogNames.cs rename to pkgs/sdk/server/src/Internal/LogNames.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/Model/Clause.cs b/pkgs/sdk/server/src/Internal/Model/Clause.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/Model/Clause.cs rename to pkgs/sdk/server/src/Internal/Model/Clause.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/Model/FeatureFlag.cs b/pkgs/sdk/server/src/Internal/Model/FeatureFlag.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/Model/FeatureFlag.cs rename to pkgs/sdk/server/src/Internal/Model/FeatureFlag.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/Model/NamespaceReadme.md b/pkgs/sdk/server/src/Internal/Model/NamespaceReadme.md similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/Model/NamespaceReadme.md rename to pkgs/sdk/server/src/Internal/Model/NamespaceReadme.md diff --git a/src/LaunchDarkly.ServerSdk/Internal/Model/Operator.cs b/pkgs/sdk/server/src/Internal/Model/Operator.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/Model/Operator.cs rename to pkgs/sdk/server/src/Internal/Model/Operator.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/Model/Segment.cs b/pkgs/sdk/server/src/Internal/Model/Segment.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/Model/Segment.cs rename to pkgs/sdk/server/src/Internal/Model/Segment.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/Model/SemanticVersion.cs b/pkgs/sdk/server/src/Internal/Model/SemanticVersion.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/Model/SemanticVersion.cs rename to pkgs/sdk/server/src/Internal/Model/SemanticVersion.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/Model/Serialization.cs b/pkgs/sdk/server/src/Internal/Model/Serialization.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/Model/Serialization.cs rename to pkgs/sdk/server/src/Internal/Model/Serialization.cs diff --git a/src/LaunchDarkly.ServerSdk/Internal/NamespaceReadme.md b/pkgs/sdk/server/src/Internal/NamespaceReadme.md similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/NamespaceReadme.md rename to pkgs/sdk/server/src/Internal/NamespaceReadme.md diff --git a/src/LaunchDarkly.ServerSdk/Internal/StandardEndpoints.cs b/pkgs/sdk/server/src/Internal/StandardEndpoints.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Internal/StandardEndpoints.cs rename to pkgs/sdk/server/src/Internal/StandardEndpoints.cs diff --git a/src/LaunchDarkly.ServerSdk/LaunchDarkly.ServerSdk.csproj b/pkgs/sdk/server/src/LaunchDarkly.ServerSdk.csproj similarity index 98% rename from src/LaunchDarkly.ServerSdk/LaunchDarkly.ServerSdk.csproj rename to pkgs/sdk/server/src/LaunchDarkly.ServerSdk.csproj index 91f3b906..211d3bbf 100644 --- a/src/LaunchDarkly.ServerSdk/LaunchDarkly.ServerSdk.csproj +++ b/pkgs/sdk/server/src/LaunchDarkly.ServerSdk.csproj @@ -46,12 +46,12 @@ - + + ../../LaunchDarkly.snk true diff --git a/src/LaunchDarkly.ServerSdk/LdClient.cs b/pkgs/sdk/server/src/LdClient.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/LdClient.cs rename to pkgs/sdk/server/src/LdClient.cs diff --git a/src/LaunchDarkly.ServerSdk/Migrations/IMigration.cs b/pkgs/sdk/server/src/Migrations/IMigration.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Migrations/IMigration.cs rename to pkgs/sdk/server/src/Migrations/IMigration.cs diff --git a/src/LaunchDarkly.ServerSdk/Migrations/Migration.cs b/pkgs/sdk/server/src/Migrations/Migration.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Migrations/Migration.cs rename to pkgs/sdk/server/src/Migrations/Migration.cs diff --git a/src/LaunchDarkly.ServerSdk/Migrations/MigrationBuilder.cs b/pkgs/sdk/server/src/Migrations/MigrationBuilder.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Migrations/MigrationBuilder.cs rename to pkgs/sdk/server/src/Migrations/MigrationBuilder.cs diff --git a/src/LaunchDarkly.ServerSdk/Migrations/MigrationExecution.cs b/pkgs/sdk/server/src/Migrations/MigrationExecution.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Migrations/MigrationExecution.cs rename to pkgs/sdk/server/src/Migrations/MigrationExecution.cs diff --git a/src/LaunchDarkly.ServerSdk/Migrations/MigrationExecutionMode.cs b/pkgs/sdk/server/src/Migrations/MigrationExecutionMode.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Migrations/MigrationExecutionMode.cs rename to pkgs/sdk/server/src/Migrations/MigrationExecutionMode.cs diff --git a/src/LaunchDarkly.ServerSdk/Migrations/MigrationMethod.cs b/pkgs/sdk/server/src/Migrations/MigrationMethod.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Migrations/MigrationMethod.cs rename to pkgs/sdk/server/src/Migrations/MigrationMethod.cs diff --git a/src/LaunchDarkly.ServerSdk/Migrations/MigrationOpTracker.cs b/pkgs/sdk/server/src/Migrations/MigrationOpTracker.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Migrations/MigrationOpTracker.cs rename to pkgs/sdk/server/src/Migrations/MigrationOpTracker.cs diff --git a/src/LaunchDarkly.ServerSdk/Migrations/MigrationOperation.cs b/pkgs/sdk/server/src/Migrations/MigrationOperation.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Migrations/MigrationOperation.cs rename to pkgs/sdk/server/src/Migrations/MigrationOperation.cs diff --git a/src/LaunchDarkly.ServerSdk/Migrations/MigrationOrigin.cs b/pkgs/sdk/server/src/Migrations/MigrationOrigin.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Migrations/MigrationOrigin.cs rename to pkgs/sdk/server/src/Migrations/MigrationOrigin.cs diff --git a/src/LaunchDarkly.ServerSdk/Migrations/MigrationResult.cs b/pkgs/sdk/server/src/Migrations/MigrationResult.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Migrations/MigrationResult.cs rename to pkgs/sdk/server/src/Migrations/MigrationResult.cs diff --git a/src/LaunchDarkly.ServerSdk/Migrations/MigrationSerialOrder.cs b/pkgs/sdk/server/src/Migrations/MigrationSerialOrder.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Migrations/MigrationSerialOrder.cs rename to pkgs/sdk/server/src/Migrations/MigrationSerialOrder.cs diff --git a/src/LaunchDarkly.ServerSdk/Migrations/MigrationStage.cs b/pkgs/sdk/server/src/Migrations/MigrationStage.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Migrations/MigrationStage.cs rename to pkgs/sdk/server/src/Migrations/MigrationStage.cs diff --git a/src/LaunchDarkly.ServerSdk/Migrations/MigrationVariation.cs b/pkgs/sdk/server/src/Migrations/MigrationVariation.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Migrations/MigrationVariation.cs rename to pkgs/sdk/server/src/Migrations/MigrationVariation.cs diff --git a/src/LaunchDarkly.ServerSdk/Migrations/MigrationWriteResult.cs b/pkgs/sdk/server/src/Migrations/MigrationWriteResult.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Migrations/MigrationWriteResult.cs rename to pkgs/sdk/server/src/Migrations/MigrationWriteResult.cs diff --git a/src/LaunchDarkly.ServerSdk/NuGet/config.install.xdt b/pkgs/sdk/server/src/NuGet/config.install.xdt similarity index 100% rename from src/LaunchDarkly.ServerSdk/NuGet/config.install.xdt rename to pkgs/sdk/server/src/NuGet/config.install.xdt diff --git a/src/LaunchDarkly.ServerSdk/NuGet/config.uninstall.xdt b/pkgs/sdk/server/src/NuGet/config.uninstall.xdt similarity index 100% rename from src/LaunchDarkly.ServerSdk/NuGet/config.uninstall.xdt rename to pkgs/sdk/server/src/NuGet/config.uninstall.xdt diff --git a/src/LaunchDarkly.ServerSdk/Properties/AssemblyInfo.cs b/pkgs/sdk/server/src/Properties/AssemblyInfo.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Properties/AssemblyInfo.cs rename to pkgs/sdk/server/src/Properties/AssemblyInfo.cs diff --git a/src/LaunchDarkly.ServerSdk/Subsystems/BigSegmentStoreTypes.cs b/pkgs/sdk/server/src/Subsystems/BigSegmentStoreTypes.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Subsystems/BigSegmentStoreTypes.cs rename to pkgs/sdk/server/src/Subsystems/BigSegmentStoreTypes.cs diff --git a/src/LaunchDarkly.ServerSdk/Subsystems/BigSegmentsConfiguration.cs b/pkgs/sdk/server/src/Subsystems/BigSegmentsConfiguration.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Subsystems/BigSegmentsConfiguration.cs rename to pkgs/sdk/server/src/Subsystems/BigSegmentsConfiguration.cs diff --git a/src/LaunchDarkly.ServerSdk/Subsystems/DataStoreTypes.cs b/pkgs/sdk/server/src/Subsystems/DataStoreTypes.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Subsystems/DataStoreTypes.cs rename to pkgs/sdk/server/src/Subsystems/DataStoreTypes.cs diff --git a/src/LaunchDarkly.ServerSdk/Subsystems/EventProcessorTypes.cs b/pkgs/sdk/server/src/Subsystems/EventProcessorTypes.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Subsystems/EventProcessorTypes.cs rename to pkgs/sdk/server/src/Subsystems/EventProcessorTypes.cs diff --git a/src/LaunchDarkly.ServerSdk/Subsystems/HookConfiguration.cs b/pkgs/sdk/server/src/Subsystems/HookConfiguration.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Subsystems/HookConfiguration.cs rename to pkgs/sdk/server/src/Subsystems/HookConfiguration.cs diff --git a/src/LaunchDarkly.ServerSdk/Subsystems/HttpConfiguration.cs b/pkgs/sdk/server/src/Subsystems/HttpConfiguration.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Subsystems/HttpConfiguration.cs rename to pkgs/sdk/server/src/Subsystems/HttpConfiguration.cs diff --git a/src/LaunchDarkly.ServerSdk/Subsystems/IBigSegmentStore.cs b/pkgs/sdk/server/src/Subsystems/IBigSegmentStore.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Subsystems/IBigSegmentStore.cs rename to pkgs/sdk/server/src/Subsystems/IBigSegmentStore.cs diff --git a/src/LaunchDarkly.ServerSdk/Subsystems/IComponentConfigurer.cs b/pkgs/sdk/server/src/Subsystems/IComponentConfigurer.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Subsystems/IComponentConfigurer.cs rename to pkgs/sdk/server/src/Subsystems/IComponentConfigurer.cs diff --git a/src/LaunchDarkly.ServerSdk/Subsystems/IDataSource.cs b/pkgs/sdk/server/src/Subsystems/IDataSource.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Subsystems/IDataSource.cs rename to pkgs/sdk/server/src/Subsystems/IDataSource.cs diff --git a/src/LaunchDarkly.ServerSdk/Subsystems/IDataSourceUpdates.cs b/pkgs/sdk/server/src/Subsystems/IDataSourceUpdates.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Subsystems/IDataSourceUpdates.cs rename to pkgs/sdk/server/src/Subsystems/IDataSourceUpdates.cs diff --git a/src/LaunchDarkly.ServerSdk/Subsystems/IDataStore.cs b/pkgs/sdk/server/src/Subsystems/IDataStore.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Subsystems/IDataStore.cs rename to pkgs/sdk/server/src/Subsystems/IDataStore.cs diff --git a/src/LaunchDarkly.ServerSdk/Subsystems/IDataStoreUpdates.cs b/pkgs/sdk/server/src/Subsystems/IDataStoreUpdates.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Subsystems/IDataStoreUpdates.cs rename to pkgs/sdk/server/src/Subsystems/IDataStoreUpdates.cs diff --git a/src/LaunchDarkly.ServerSdk/Subsystems/IDiagnosticDescription.cs b/pkgs/sdk/server/src/Subsystems/IDiagnosticDescription.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Subsystems/IDiagnosticDescription.cs rename to pkgs/sdk/server/src/Subsystems/IDiagnosticDescription.cs diff --git a/src/LaunchDarkly.ServerSdk/Subsystems/IEventProcessor.cs b/pkgs/sdk/server/src/Subsystems/IEventProcessor.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Subsystems/IEventProcessor.cs rename to pkgs/sdk/server/src/Subsystems/IEventProcessor.cs diff --git a/src/LaunchDarkly.ServerSdk/Subsystems/IPersistentDataStore.cs b/pkgs/sdk/server/src/Subsystems/IPersistentDataStore.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Subsystems/IPersistentDataStore.cs rename to pkgs/sdk/server/src/Subsystems/IPersistentDataStore.cs diff --git a/src/LaunchDarkly.ServerSdk/Subsystems/IPersistentDataStoreAsync.cs b/pkgs/sdk/server/src/Subsystems/IPersistentDataStoreAsync.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Subsystems/IPersistentDataStoreAsync.cs rename to pkgs/sdk/server/src/Subsystems/IPersistentDataStoreAsync.cs diff --git a/src/LaunchDarkly.ServerSdk/Subsystems/LdClientContext.cs b/pkgs/sdk/server/src/Subsystems/LdClientContext.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Subsystems/LdClientContext.cs rename to pkgs/sdk/server/src/Subsystems/LdClientContext.cs diff --git a/src/LaunchDarkly.ServerSdk/Subsystems/LoggingConfiguration.cs b/pkgs/sdk/server/src/Subsystems/LoggingConfiguration.cs similarity index 100% rename from src/LaunchDarkly.ServerSdk/Subsystems/LoggingConfiguration.cs rename to pkgs/sdk/server/src/Subsystems/LoggingConfiguration.cs diff --git a/src/LaunchDarkly.ServerSdk/app.config b/pkgs/sdk/server/src/app.config similarity index 100% rename from src/LaunchDarkly.ServerSdk/app.config rename to pkgs/sdk/server/src/app.config diff --git a/test/LaunchDarkly.ServerSdk.Tests/AssertHelpers.cs b/pkgs/sdk/server/test/AssertHelpers.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/AssertHelpers.cs rename to pkgs/sdk/server/test/AssertHelpers.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/BaseTest.cs b/pkgs/sdk/server/test/BaseTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/BaseTest.cs rename to pkgs/sdk/server/test/BaseTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/ConfigurationTest.cs b/pkgs/sdk/server/test/ConfigurationTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/ConfigurationTest.cs rename to pkgs/sdk/server/test/ConfigurationTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/DataModelTest.cs b/pkgs/sdk/server/test/DataModelTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/DataModelTest.cs rename to pkgs/sdk/server/test/DataModelTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/FeatureFlagsStateTest.cs b/pkgs/sdk/server/test/FeatureFlagsStateTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/FeatureFlagsStateTest.cs rename to pkgs/sdk/server/test/FeatureFlagsStateTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Hooks/EvaluationSeriesTest.cs b/pkgs/sdk/server/test/Hooks/EvaluationSeriesTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Hooks/EvaluationSeriesTest.cs rename to pkgs/sdk/server/test/Hooks/EvaluationSeriesTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Hooks/HookTest.cs b/pkgs/sdk/server/test/Hooks/HookTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Hooks/HookTest.cs rename to pkgs/sdk/server/test/Hooks/HookTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/ILdClientExtensionsTests.cs b/pkgs/sdk/server/test/ILdClientExtensionsTests.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/ILdClientExtensionsTests.cs rename to pkgs/sdk/server/test/ILdClientExtensionsTests.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Integrations/BigSegmentsConfigurationBuilderTest.cs b/pkgs/sdk/server/test/Integrations/BigSegmentsConfigurationBuilderTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Integrations/BigSegmentsConfigurationBuilderTest.cs rename to pkgs/sdk/server/test/Integrations/BigSegmentsConfigurationBuilderTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Integrations/EventProcessorBuilderTest.cs b/pkgs/sdk/server/test/Integrations/EventProcessorBuilderTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Integrations/EventProcessorBuilderTest.cs rename to pkgs/sdk/server/test/Integrations/EventProcessorBuilderTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Integrations/FileDataSourceBuilderTest.cs b/pkgs/sdk/server/test/Integrations/FileDataSourceBuilderTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Integrations/FileDataSourceBuilderTest.cs rename to pkgs/sdk/server/test/Integrations/FileDataSourceBuilderTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Integrations/HttpConfigurationBuilderTest.cs b/pkgs/sdk/server/test/Integrations/HttpConfigurationBuilderTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Integrations/HttpConfigurationBuilderTest.cs rename to pkgs/sdk/server/test/Integrations/HttpConfigurationBuilderTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Integrations/LoggingConfigurationBuilderTest.cs b/pkgs/sdk/server/test/Integrations/LoggingConfigurationBuilderTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Integrations/LoggingConfigurationBuilderTest.cs rename to pkgs/sdk/server/test/Integrations/LoggingConfigurationBuilderTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Integrations/PollingDataSourceBuilderTest.cs b/pkgs/sdk/server/test/Integrations/PollingDataSourceBuilderTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Integrations/PollingDataSourceBuilderTest.cs rename to pkgs/sdk/server/test/Integrations/PollingDataSourceBuilderTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Integrations/ServiceEndpointsBuilderTest.cs b/pkgs/sdk/server/test/Integrations/ServiceEndpointsBuilderTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Integrations/ServiceEndpointsBuilderTest.cs rename to pkgs/sdk/server/test/Integrations/ServiceEndpointsBuilderTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Integrations/StreamingDataSourceBuilderTest.cs b/pkgs/sdk/server/test/Integrations/StreamingDataSourceBuilderTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Integrations/StreamingDataSourceBuilderTest.cs rename to pkgs/sdk/server/test/Integrations/StreamingDataSourceBuilderTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Integrations/TestDataTest.cs b/pkgs/sdk/server/test/Integrations/TestDataTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Integrations/TestDataTest.cs rename to pkgs/sdk/server/test/Integrations/TestDataTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Integrations/TestDataWithClientTest.cs b/pkgs/sdk/server/test/Integrations/TestDataWithClientTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Integrations/TestDataWithClientTest.cs rename to pkgs/sdk/server/test/Integrations/TestDataWithClientTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Internal/BigSegments/BigSegmentsStatusProviderImplTest.cs b/pkgs/sdk/server/test/Internal/BigSegments/BigSegmentsStatusProviderImplTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Internal/BigSegments/BigSegmentsStatusProviderImplTest.cs rename to pkgs/sdk/server/test/Internal/BigSegments/BigSegmentsStatusProviderImplTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Internal/BigSegments/BigSegmentsStoreWrapperTest.cs b/pkgs/sdk/server/test/Internal/BigSegments/BigSegmentsStoreWrapperTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Internal/BigSegments/BigSegmentsStoreWrapperTest.cs rename to pkgs/sdk/server/test/Internal/BigSegments/BigSegmentsStoreWrapperTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Internal/BigSegments/MembershipBuilderTest.cs b/pkgs/sdk/server/test/Internal/BigSegments/MembershipBuilderTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Internal/BigSegments/MembershipBuilderTest.cs rename to pkgs/sdk/server/test/Internal/BigSegments/MembershipBuilderTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Internal/DataSources/DataModelDependenciesTest.cs b/pkgs/sdk/server/test/Internal/DataSources/DataModelDependenciesTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Internal/DataSources/DataModelDependenciesTest.cs rename to pkgs/sdk/server/test/Internal/DataSources/DataModelDependenciesTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Internal/DataSources/DataSourceStatusProviderImplTest.cs b/pkgs/sdk/server/test/Internal/DataSources/DataSourceStatusProviderImplTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Internal/DataSources/DataSourceStatusProviderImplTest.cs rename to pkgs/sdk/server/test/Internal/DataSources/DataSourceStatusProviderImplTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Internal/DataSources/DataSourceUpdatesImplTest.cs b/pkgs/sdk/server/test/Internal/DataSources/DataSourceUpdatesImplTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Internal/DataSources/DataSourceUpdatesImplTest.cs rename to pkgs/sdk/server/test/Internal/DataSources/DataSourceUpdatesImplTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Internal/DataSources/FileDataSourceTest.cs b/pkgs/sdk/server/test/Internal/DataSources/FileDataSourceTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Internal/DataSources/FileDataSourceTest.cs rename to pkgs/sdk/server/test/Internal/DataSources/FileDataSourceTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Internal/DataSources/FlagFileDataMergerTest.cs b/pkgs/sdk/server/test/Internal/DataSources/FlagFileDataMergerTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Internal/DataSources/FlagFileDataMergerTest.cs rename to pkgs/sdk/server/test/Internal/DataSources/FlagFileDataMergerTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Internal/DataSources/PollingDataSourceTest.cs b/pkgs/sdk/server/test/Internal/DataSources/PollingDataSourceTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Internal/DataSources/PollingDataSourceTest.cs rename to pkgs/sdk/server/test/Internal/DataSources/PollingDataSourceTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Internal/DataSources/StreamProcessorEventsTest.cs b/pkgs/sdk/server/test/Internal/DataSources/StreamProcessorEventsTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Internal/DataSources/StreamProcessorEventsTest.cs rename to pkgs/sdk/server/test/Internal/DataSources/StreamProcessorEventsTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Internal/DataSources/StreamingDataSourceTest.cs b/pkgs/sdk/server/test/Internal/DataSources/StreamingDataSourceTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Internal/DataSources/StreamingDataSourceTest.cs rename to pkgs/sdk/server/test/Internal/DataSources/StreamingDataSourceTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Internal/DataStores/DataStoreSorterTest.cs b/pkgs/sdk/server/test/Internal/DataStores/DataStoreSorterTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Internal/DataStores/DataStoreSorterTest.cs rename to pkgs/sdk/server/test/Internal/DataStores/DataStoreSorterTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Internal/DataStores/DataStoreStatusProviderImplTest.cs b/pkgs/sdk/server/test/Internal/DataStores/DataStoreStatusProviderImplTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Internal/DataStores/DataStoreStatusProviderImplTest.cs rename to pkgs/sdk/server/test/Internal/DataStores/DataStoreStatusProviderImplTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Internal/DataStores/DataStoreTestBase.cs b/pkgs/sdk/server/test/Internal/DataStores/DataStoreTestBase.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Internal/DataStores/DataStoreTestBase.cs rename to pkgs/sdk/server/test/Internal/DataStores/DataStoreTestBase.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Internal/DataStores/DataStoreTestTypes.cs b/pkgs/sdk/server/test/Internal/DataStores/DataStoreTestTypes.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Internal/DataStores/DataStoreTestTypes.cs rename to pkgs/sdk/server/test/Internal/DataStores/DataStoreTestTypes.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Internal/DataStores/DataStoreUpdatesImplTest.cs b/pkgs/sdk/server/test/Internal/DataStores/DataStoreUpdatesImplTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Internal/DataStores/DataStoreUpdatesImplTest.cs rename to pkgs/sdk/server/test/Internal/DataStores/DataStoreUpdatesImplTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Internal/DataStores/InMemoryDataStoreTest.cs b/pkgs/sdk/server/test/Internal/DataStores/InMemoryDataStoreTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Internal/DataStores/InMemoryDataStoreTest.cs rename to pkgs/sdk/server/test/Internal/DataStores/InMemoryDataStoreTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Internal/DataStores/PersistentStoreWrapperTestAsync.cs b/pkgs/sdk/server/test/Internal/DataStores/PersistentStoreWrapperTestAsync.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Internal/DataStores/PersistentStoreWrapperTestAsync.cs rename to pkgs/sdk/server/test/Internal/DataStores/PersistentStoreWrapperTestAsync.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Internal/DataStores/PersistentStoreWrapperTestBase.cs b/pkgs/sdk/server/test/Internal/DataStores/PersistentStoreWrapperTestBase.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Internal/DataStores/PersistentStoreWrapperTestBase.cs rename to pkgs/sdk/server/test/Internal/DataStores/PersistentStoreWrapperTestBase.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Internal/DataStores/PersistentStoreWrapperTestSync.cs b/pkgs/sdk/server/test/Internal/DataStores/PersistentStoreWrapperTestSync.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Internal/DataStores/PersistentStoreWrapperTestSync.cs rename to pkgs/sdk/server/test/Internal/DataStores/PersistentStoreWrapperTestSync.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Internal/Evaluation/BucketingTest.cs b/pkgs/sdk/server/test/Internal/Evaluation/BucketingTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Internal/Evaluation/BucketingTest.cs rename to pkgs/sdk/server/test/Internal/Evaluation/BucketingTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Internal/Evaluation/EvaluatorBigSegmentTest.cs b/pkgs/sdk/server/test/Internal/Evaluation/EvaluatorBigSegmentTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Internal/Evaluation/EvaluatorBigSegmentTest.cs rename to pkgs/sdk/server/test/Internal/Evaluation/EvaluatorBigSegmentTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Internal/Evaluation/EvaluatorClauseTest.cs b/pkgs/sdk/server/test/Internal/Evaluation/EvaluatorClauseTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Internal/Evaluation/EvaluatorClauseTest.cs rename to pkgs/sdk/server/test/Internal/Evaluation/EvaluatorClauseTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Internal/Evaluation/EvaluatorFlagTest.cs b/pkgs/sdk/server/test/Internal/Evaluation/EvaluatorFlagTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Internal/Evaluation/EvaluatorFlagTest.cs rename to pkgs/sdk/server/test/Internal/Evaluation/EvaluatorFlagTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Internal/Evaluation/EvaluatorPrerequisitesTest.cs b/pkgs/sdk/server/test/Internal/Evaluation/EvaluatorPrerequisitesTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Internal/Evaluation/EvaluatorPrerequisitesTest.cs rename to pkgs/sdk/server/test/Internal/Evaluation/EvaluatorPrerequisitesTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Internal/Evaluation/EvaluatorRuleTest.cs b/pkgs/sdk/server/test/Internal/Evaluation/EvaluatorRuleTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Internal/Evaluation/EvaluatorRuleTest.cs rename to pkgs/sdk/server/test/Internal/Evaluation/EvaluatorRuleTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Internal/Evaluation/EvaluatorSegmentMatchTest.cs b/pkgs/sdk/server/test/Internal/Evaluation/EvaluatorSegmentMatchTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Internal/Evaluation/EvaluatorSegmentMatchTest.cs rename to pkgs/sdk/server/test/Internal/Evaluation/EvaluatorSegmentMatchTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Internal/Evaluation/EvaluatorTargetTest.cs b/pkgs/sdk/server/test/Internal/Evaluation/EvaluatorTargetTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Internal/Evaluation/EvaluatorTargetTest.cs rename to pkgs/sdk/server/test/Internal/Evaluation/EvaluatorTargetTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Internal/Evaluation/EvaluatorTestUtil.cs b/pkgs/sdk/server/test/Internal/Evaluation/EvaluatorTestUtil.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Internal/Evaluation/EvaluatorTestUtil.cs rename to pkgs/sdk/server/test/Internal/Evaluation/EvaluatorTestUtil.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Internal/Evaluation/RolloutRandomizationConsistencyTest.cs b/pkgs/sdk/server/test/Internal/Evaluation/RolloutRandomizationConsistencyTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Internal/Evaluation/RolloutRandomizationConsistencyTest.cs rename to pkgs/sdk/server/test/Internal/Evaluation/RolloutRandomizationConsistencyTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Internal/Events/ServerDiagnosticStoreTest.cs b/pkgs/sdk/server/test/Internal/Events/ServerDiagnosticStoreTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Internal/Events/ServerDiagnosticStoreTest.cs rename to pkgs/sdk/server/test/Internal/Events/ServerDiagnosticStoreTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Internal/FlagTrackerImplTest.cs b/pkgs/sdk/server/test/Internal/FlagTrackerImplTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Internal/FlagTrackerImplTest.cs rename to pkgs/sdk/server/test/Internal/FlagTrackerImplTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Internal/LRUCacheSetTest.cs b/pkgs/sdk/server/test/Internal/LRUCacheSetTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Internal/LRUCacheSetTest.cs rename to pkgs/sdk/server/test/Internal/LRUCacheSetTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Internal/Model/DataSetBuilder.cs b/pkgs/sdk/server/test/Internal/Model/DataSetBuilder.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Internal/Model/DataSetBuilder.cs rename to pkgs/sdk/server/test/Internal/Model/DataSetBuilder.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Internal/Model/FeatureFlagBuilder.cs b/pkgs/sdk/server/test/Internal/Model/FeatureFlagBuilder.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Internal/Model/FeatureFlagBuilder.cs rename to pkgs/sdk/server/test/Internal/Model/FeatureFlagBuilder.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Internal/Model/OperatorTest.cs b/pkgs/sdk/server/test/Internal/Model/OperatorTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Internal/Model/OperatorTest.cs rename to pkgs/sdk/server/test/Internal/Model/OperatorTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Internal/Model/SegmentBuilder.cs b/pkgs/sdk/server/test/Internal/Model/SegmentBuilder.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Internal/Model/SegmentBuilder.cs rename to pkgs/sdk/server/test/Internal/Model/SegmentBuilder.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Internal/Model/SemanticVersionTest.cs b/pkgs/sdk/server/test/Internal/Model/SemanticVersionTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Internal/Model/SemanticVersionTest.cs rename to pkgs/sdk/server/test/Internal/Model/SemanticVersionTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/LaunchDarkly.ServerSdk.Tests.csproj b/pkgs/sdk/server/test/LaunchDarkly.ServerSdk.Tests.csproj similarity index 95% rename from test/LaunchDarkly.ServerSdk.Tests/LaunchDarkly.ServerSdk.Tests.csproj rename to pkgs/sdk/server/test/LaunchDarkly.ServerSdk.Tests.csproj index 7641cadd..08e77baa 100644 --- a/test/LaunchDarkly.ServerSdk.Tests/LaunchDarkly.ServerSdk.Tests.csproj +++ b/pkgs/sdk/server/test/LaunchDarkly.ServerSdk.Tests.csproj @@ -14,7 +14,7 @@ - + diff --git a/test/LaunchDarkly.ServerSdk.Tests/LdClientBigSegmentsTest.cs b/pkgs/sdk/server/test/LdClientBigSegmentsTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/LdClientBigSegmentsTest.cs rename to pkgs/sdk/server/test/LdClientBigSegmentsTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/LdClientDiagnosticEventTest.cs b/pkgs/sdk/server/test/LdClientDiagnosticEventTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/LdClientDiagnosticEventTest.cs rename to pkgs/sdk/server/test/LdClientDiagnosticEventTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/LdClientEndToEndTest.cs b/pkgs/sdk/server/test/LdClientEndToEndTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/LdClientEndToEndTest.cs rename to pkgs/sdk/server/test/LdClientEndToEndTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/LdClientEvaluationTest.cs b/pkgs/sdk/server/test/LdClientEvaluationTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/LdClientEvaluationTest.cs rename to pkgs/sdk/server/test/LdClientEvaluationTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/LdClientEventTest.cs b/pkgs/sdk/server/test/LdClientEventTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/LdClientEventTest.cs rename to pkgs/sdk/server/test/LdClientEventTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/LdClientExternalUpdatesOnlyTest.cs b/pkgs/sdk/server/test/LdClientExternalUpdatesOnlyTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/LdClientExternalUpdatesOnlyTest.cs rename to pkgs/sdk/server/test/LdClientExternalUpdatesOnlyTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/LdClientHooksTest.cs b/pkgs/sdk/server/test/LdClientHooksTest.cs similarity index 98% rename from test/LaunchDarkly.ServerSdk.Tests/LdClientHooksTest.cs rename to pkgs/sdk/server/test/LdClientHooksTest.cs index d63c1fcb..9600bced 100644 --- a/test/LaunchDarkly.ServerSdk.Tests/LdClientHooksTest.cs +++ b/pkgs/sdk/server/test/LdClientHooksTest.cs @@ -1,13 +1,8 @@ using System; using System.Collections.Generic; using System.Collections.Immutable; -using System.Collections.ObjectModel; using System.Linq; using LaunchDarkly.Sdk.Server.Hooks; -using LaunchDarkly.Sdk.Server.Integrations; -using LaunchDarkly.Sdk.Server.Interfaces; -using LaunchDarkly.Sdk.Server.Subsystems; -using LaunchDarkly.TestHelpers; using Xunit; using Xunit.Abstractions; @@ -188,7 +183,6 @@ private Dictionary GenerateVariationMethods(Context context, strin }; } - [Fact] public void ClientExecutesConfiguredHooks() { @@ -264,7 +258,6 @@ public void ClientExecutesConfiguredHooks() } } } - } } } diff --git a/test/LaunchDarkly.ServerSdk.Tests/LdClientListenersTest.cs b/pkgs/sdk/server/test/LdClientListenersTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/LdClientListenersTest.cs rename to pkgs/sdk/server/test/LdClientListenersTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/LdClientOfflineTest.cs b/pkgs/sdk/server/test/LdClientOfflineTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/LdClientOfflineTest.cs rename to pkgs/sdk/server/test/LdClientOfflineTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/LdClientServiceEndpointsTest.cs b/pkgs/sdk/server/test/LdClientServiceEndpointsTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/LdClientServiceEndpointsTest.cs rename to pkgs/sdk/server/test/LdClientServiceEndpointsTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/LdClientTest.cs b/pkgs/sdk/server/test/LdClientTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/LdClientTest.cs rename to pkgs/sdk/server/test/LdClientTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Migrations/BasicMigrationExecutor.cs b/pkgs/sdk/server/test/Migrations/BasicMigrationExecutor.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Migrations/BasicMigrationExecutor.cs rename to pkgs/sdk/server/test/Migrations/BasicMigrationExecutor.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Migrations/MigrationBuilderTest.cs b/pkgs/sdk/server/test/Migrations/MigrationBuilderTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Migrations/MigrationBuilderTest.cs rename to pkgs/sdk/server/test/Migrations/MigrationBuilderTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Migrations/MigrationOpTrackerTest.cs b/pkgs/sdk/server/test/Migrations/MigrationOpTrackerTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Migrations/MigrationOpTrackerTest.cs rename to pkgs/sdk/server/test/Migrations/MigrationOpTrackerTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Migrations/MigrationStageTest.cs b/pkgs/sdk/server/test/Migrations/MigrationStageTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Migrations/MigrationStageTest.cs rename to pkgs/sdk/server/test/Migrations/MigrationStageTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/Migrations/MigrationTest.cs b/pkgs/sdk/server/test/Migrations/MigrationTest.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/Migrations/MigrationTest.cs rename to pkgs/sdk/server/test/Migrations/MigrationTest.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/MockComponents.cs b/pkgs/sdk/server/test/MockComponents.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/MockComponents.cs rename to pkgs/sdk/server/test/MockComponents.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/MockResponses.cs b/pkgs/sdk/server/test/MockResponses.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/MockResponses.cs rename to pkgs/sdk/server/test/MockResponses.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/TestFiles/all-properties.json b/pkgs/sdk/server/test/TestFiles/all-properties.json similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/TestFiles/all-properties.json rename to pkgs/sdk/server/test/TestFiles/all-properties.json diff --git a/test/LaunchDarkly.ServerSdk.Tests/TestFiles/all-properties.yml b/pkgs/sdk/server/test/TestFiles/all-properties.yml similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/TestFiles/all-properties.yml rename to pkgs/sdk/server/test/TestFiles/all-properties.yml diff --git a/test/LaunchDarkly.ServerSdk.Tests/TestFiles/bad-file.txt b/pkgs/sdk/server/test/TestFiles/bad-file.txt similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/TestFiles/bad-file.txt rename to pkgs/sdk/server/test/TestFiles/bad-file.txt diff --git a/test/LaunchDarkly.ServerSdk.Tests/TestFiles/flag-only.json b/pkgs/sdk/server/test/TestFiles/flag-only.json similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/TestFiles/flag-only.json rename to pkgs/sdk/server/test/TestFiles/flag-only.json diff --git a/test/LaunchDarkly.ServerSdk.Tests/TestFiles/segment-only.json b/pkgs/sdk/server/test/TestFiles/segment-only.json similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/TestFiles/segment-only.json rename to pkgs/sdk/server/test/TestFiles/segment-only.json diff --git a/test/LaunchDarkly.ServerSdk.Tests/TestHttpUtils.cs b/pkgs/sdk/server/test/TestHttpUtils.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/TestHttpUtils.cs rename to pkgs/sdk/server/test/TestHttpUtils.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/TestLoggingHelpers.cs b/pkgs/sdk/server/test/TestLoggingHelpers.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/TestLoggingHelpers.cs rename to pkgs/sdk/server/test/TestLoggingHelpers.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/TestUtils.cs b/pkgs/sdk/server/test/TestUtils.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/TestUtils.cs rename to pkgs/sdk/server/test/TestUtils.cs diff --git a/test/LaunchDarkly.ServerSdk.Tests/VariationMethodsDesc.cs b/pkgs/sdk/server/test/VariationMethodsDesc.cs similarity index 100% rename from test/LaunchDarkly.ServerSdk.Tests/VariationMethodsDesc.cs rename to pkgs/sdk/server/test/VariationMethodsDesc.cs diff --git a/pkgs/telemetry/docfx.json b/pkgs/telemetry/docfx.json new file mode 100644 index 00000000..293c9287 --- /dev/null +++ b/pkgs/telemetry/docfx.json @@ -0,0 +1,48 @@ +{ + "metadata": [ + { + "src": [ + { + "src": "./src", + "files": [ + "**/*.csproj", + "**/bin/**/**LaunchDarkly**.dll" + ] + } + ], + "dest": "./api", + "properties" : { + "Configuration": "Debug" + }, + } + ], + "build": { + "content": [ + { + "files": [ + "**/*.{md,yml}" + ], + "exclude": [ + "docs/**" + ] + } + ], + "resource": [ + { + "files": [ + "images/**" + ] + } + ], + "output": "docs", + "template": [ + "default" + ], + "globalMetadata": { + "_appName": "LaunchDarkly Dotnet Server SDK Telemetry Integration", + "_appTitle": "LaunchDarkly Dotnet Server SDK Telemetry Integration", + "_enableSearch": true, + "pdf": false + } + } +} diff --git a/pkgs/telemetry/src/LaunchDarkly.ServerSdk.Telemetry.csproj b/pkgs/telemetry/src/LaunchDarkly.ServerSdk.Telemetry.csproj new file mode 100644 index 00000000..0d72ef35 --- /dev/null +++ b/pkgs/telemetry/src/LaunchDarkly.ServerSdk.Telemetry.csproj @@ -0,0 +1,56 @@ + + + + 0.1.0 + + + netstandard2.0;net462;net6.0 + $(BUILDFRAMEWORKS) + portable + LaunchDarkly.ServerSdk.Telemetry + Library + LaunchDarkly.ServerSdk.Telemetry + LaunchDarkly.Sdk.Server.Telemetry + 7.3 + LaunchDarkly Server-Side .NET SDK Telemetry Integrations + LaunchDarkly + LaunchDarkly + LaunchDarkly + Copyright 2024 LaunchDarkly + Apache-2.0 + https://github.com/launchdarkly/dotnet-server-sdk + https://github.com/launchdarkly/dotnet-server-sdk + main + true + snupkg + + + true + + + 1570,1571,1572,1573,1574,1580,1581,1584,1591,1710,1711,1712 + + + + + + + + + + + + + ../../LaunchDarkly.snk + true + + + + bin\$(Configuration)\$(TargetFramework)\LaunchDarkly.ServerSdk.Telemetry.xml + + diff --git a/pkgs/telemetry/src/Telemetry/TracingHook.cs b/pkgs/telemetry/src/Telemetry/TracingHook.cs new file mode 100644 index 00000000..e459ef90 --- /dev/null +++ b/pkgs/telemetry/src/Telemetry/TracingHook.cs @@ -0,0 +1,192 @@ +using System.Collections.Immutable; +using System.Diagnostics; +using LaunchDarkly.Sdk.Internal; +using LaunchDarkly.Sdk.Server.Hooks; + +namespace LaunchDarkly.Sdk.Server.Telemetry +{ + + using SeriesData = ImmutableDictionary; + + /// + /// TracingHookBuilder creates a s. + /// + public class TracingHookBuilder + { + private bool _createActivities; + private bool _includeVariant; + + internal TracingHookBuilder() + { + _createActivities = false; + _includeVariant = false; + } + + /// + /// The TracingHook will create s for flag evaluations. + /// The activities will be children of the current activity, if one exists, or root activities. + /// Disabled by default. + /// + /// NOTE: This is an experimental option; it may be removed and behavior is + /// subject to change within minor versions. + /// + /// true to create activities, false otherwise + /// this builder + public TracingHookBuilder CreateActivities(bool createActivities = true) + { + _createActivities = createActivities; + return this; + } + + /// + /// The TracingHook will include the flag variant in the current activity, if one exists. + /// The variant representation is a JSON string. Disabled by default. + /// + /// true to include variants, false otherwise + /// this builder + public TracingHookBuilder IncludeVariant(bool includeVariant = true) + { + _includeVariant = includeVariant; + return this; + } + + /// + /// Builds the with the configured options. + /// + /// The hook may be passed into the SDK's Hook configuration as-is. + /// + /// the new hook + public TracingHook Build() + { + return new TracingHook(new TracingHook.Options(_createActivities, _includeVariant)); + } + } + + /// + /// TracingHook is a that adds tracing capabilities to the LaunchDarkly SDK for feature flag + /// evaluations. + /// + public class TracingHook : Hook + { + + /// + /// Used to create new activities if the TracingHook is configured to create them. + /// + private static readonly ActivitySource Source = new ActivitySource("LaunchDarkly.ServerSdk", + AssemblyVersions.GetAssemblyVersionForType(typeof(LdClient)).ToString()); + + /// + /// Returns the name of the ActivitySource that the TracingHook uses to generate Activities. + /// + public static string ActivitySourceName => Source.Name; + + private static class SemanticAttributes + { + public const string EventName = "feature_flag"; + public const string FeatureFlagKey = "feature_flag.key"; + public const string FeatureFlagProviderName = "feature_flag.provider_name"; + public const string FeatureFlagVariant = "feature_flag.variant"; + public const string FeatureFlagContextKeyAttributeName = "feature_flag.context.key"; + } + + internal struct Options + { + public bool CreateActivities { get; } + public bool IncludeVariant { get; } + + public Options(bool createActivities, bool includeVariant) + { + CreateActivities = createActivities; + IncludeVariant = includeVariant; + } + } + + private readonly Options _options; + + private const string ActivityFieldKey = "evalActivity"; + + internal TracingHook(Options options) : base("LaunchDarkly Tracing Hook") + { + _options = options; + } + + /// + /// Returns a which can be used to create a . + /// + /// + /// the builder + public static TracingHookBuilder Builder() => new TracingHookBuilder(); + + /// + /// Returns the default TracingHook. By default, the hook will attach an event to the current activity. + /// + /// To change the configuration, see . + /// + /// + public static TracingHook Default() => Builder().Build(); + + /// + /// Optionally creates a new Activity for the evaluation of a feature flag. + /// + /// the evaluation parameters + /// the series data + /// unchanged data if CreateActivities is disabled, or data containing a reference to the created activity + public override SeriesData BeforeEvaluation(EvaluationSeriesContext context, SeriesData data) + { + if (!_options.CreateActivities) return data; + + var attrs = new ActivityTagsCollection + { + { SemanticAttributes.FeatureFlagKey, context.FlagKey }, + { SemanticAttributes.FeatureFlagContextKeyAttributeName, context.Context.FullyQualifiedKey } + }; + + // If there is a parent activity, then our new activity should be a child of it. + // Otherwise, our new activity will be a root activity. + var parentContext = Activity.Current?.Context ?? new ActivityContext(); + + // This is an internal activity because LaunchDarkly SDK usage is an internal operation of an application. + var activity = Source.StartActivity( context.Method, ActivityKind.Internal, parentContext, attrs); + return new SeriesDataBuilder(data).Set(ActivityFieldKey, activity).Build(); + } + + /// + /// Ends the activity created in BeforeEvaluation, if it exists. Adds the feature flag key, provider name, and context key + /// to the existing activity. If IncludeVariant is enabled, also adds the variant. + /// + /// the evaluation parameters + /// the series data + /// the evaluation details + /// + public override SeriesData AfterEvaluation(EvaluationSeriesContext context, SeriesData data, EvaluationDetail detail) + { + if (_options.CreateActivities && data.TryGetValue(ActivityFieldKey, out var value)) + { + try + { + var activity = (Activity) value; + activity?.Stop(); + } + catch (System.InvalidCastException) + { + // This should never happen, but if it does, don't crash the application. + } + } + + var attributes = new ActivityTagsCollection + { + {SemanticAttributes.FeatureFlagKey, context.FlagKey}, + {SemanticAttributes.FeatureFlagProviderName, "LaunchDarkly"}, + {SemanticAttributes.FeatureFlagContextKeyAttributeName, context.Context.FullyQualifiedKey}, + }; + + if (_options.IncludeVariant) + { + attributes.Add(SemanticAttributes.FeatureFlagVariant, detail.Value.ToJsonString()); + } + + Activity.Current?.AddEvent(new ActivityEvent(name: SemanticAttributes.EventName, tags: attributes)); + return data; + } + } +} diff --git a/pkgs/telemetry/test/LaunchDarkly.ServerSdk.Telemetry.Tests.csproj b/pkgs/telemetry/test/LaunchDarkly.ServerSdk.Telemetry.Tests.csproj new file mode 100644 index 00000000..d57fe06e --- /dev/null +++ b/pkgs/telemetry/test/LaunchDarkly.ServerSdk.Telemetry.Tests.csproj @@ -0,0 +1,44 @@ + + + + netstandard2.0;net462;net6.0 + $(TESTFRAMEWORK) + LaunchDarkly.ServerSdk.Telemetry.Tests + LaunchDarkly.ServerSdk.Telemetry.Tests + false + true + LaunchDarkly.Sdk.Server.Telemetry + + + + + + + + + + + + + + + + Always + + + Always + + + Always + + + Always + + + Always + + + diff --git a/pkgs/telemetry/test/Telemetry/TracingHookTests.cs b/pkgs/telemetry/test/Telemetry/TracingHookTests.cs new file mode 100644 index 00000000..db1d82e5 --- /dev/null +++ b/pkgs/telemetry/test/Telemetry/TracingHookTests.cs @@ -0,0 +1,211 @@ +using System.Collections.Generic; +using System.Collections.ObjectModel; +using System.Diagnostics; +using System.Linq; +using LaunchDarkly.Sdk.Server.Hooks; +using OpenTelemetry.Resources; +using OpenTelemetry.Trace; +using Xunit; + +namespace LaunchDarkly.Sdk.Server.Telemetry +{ + public class TestTracingHook + { + [Fact] + public void CanConstructTracingHook() + { + var hook = TracingHook.Default(); + Assert.NotNull(hook); + Assert.Equal("LaunchDarkly Tracing Hook", hook.Metadata.Name); + } + + [Fact] + public void CanRetrieveActivitySourceName() + { + Assert.NotEmpty(TracingHook.ActivitySourceName); + } + + [Theory] + [InlineData(false, false)] + [InlineData(false, true)] + [InlineData(true, false)] + [InlineData(true, true)] + public void ConfigurationOptionsDoNotThrowExceptions(bool includeVariant, bool createSpans) + { + var hook = TracingHook.Builder() + .IncludeVariant(includeVariant) + .CreateActivities(createSpans) + .Build(); + var context = new EvaluationSeriesContext("foo", Context.New("bar"), LdValue.Null, "testMethod"); + var data = hook.BeforeEvaluation(context, new SeriesDataBuilder().Build()); + hook.AfterEvaluation(context, data, new EvaluationDetail()); + } + + [Fact] + public void CallingDisposeDoesNotThrowException() + { + var hook = TracingHook.Default(); + hook.Dispose(); + } + + [Theory] + [InlineData(true)] + [InlineData(false)] + public void TracingHookCreatesRootSpans(bool createSpans) + { + ICollection exportedItems = new Collection(); + + var tracerProvider = OpenTelemetry.Sdk.CreateTracerProviderBuilder() + .AddSource(TracingHook.ActivitySourceName) + .AddInMemoryExporter(exportedItems) + .Build(); + + var hookUnderTest = TracingHook.Builder().CreateActivities(createSpans).Build(); + var featureKey = "feature-key"; + var context = Context.New("foo"); + + var evalContext1 = new EvaluationSeriesContext(featureKey, context, LdValue.Of(true), "LdClient.BoolVariation"); + var data1 = hookUnderTest.BeforeEvaluation(evalContext1, new SeriesDataBuilder().Build()); + hookUnderTest.AfterEvaluation(evalContext1, data1, + new EvaluationDetail(LdValue.Of(true), 0, EvaluationReason.FallthroughReason)); + + var evalContext2 = new EvaluationSeriesContext(featureKey, context, LdValue.Of("default"), "LdClient.StringVariation"); + var data2 = hookUnderTest.BeforeEvaluation(evalContext2, new SeriesDataBuilder().Build()); + hookUnderTest.AfterEvaluation(evalContext2, data2, + new EvaluationDetail(LdValue.Of("default"), 0, EvaluationReason.FallthroughReason)); + + var items = exportedItems.ToList(); + + if (createSpans) + { + // If we're creating spans, then we should have two Activities, with the correct operation names. + // To check that they are root spans, check that the parent is null. + Assert.Equal(2, items.Count); + Assert.Equal("LdClient.BoolVariation", items[0].OperationName); + Assert.Equal("LdClient.StringVariation", items[1].OperationName); + Assert.True(items.All(i => i.Parent == null)); + } + else + { + // Otherwise, there should be no Activities. + Assert.Empty(exportedItems); + } + } + + + [Theory] + [InlineData(true)] + [InlineData(false)] + public void TracingHookCreatesChildSpans(bool createSpans) + { + ICollection exportedItems = new Collection(); + + var testSource = new ActivitySource("test-source", "1.0.0"); + + var tracerProvider = OpenTelemetry.Sdk.CreateTracerProviderBuilder() + .AddSource("test-source") + .AddSource(TracingHook.ActivitySourceName) + .SetResourceBuilder( + ResourceBuilder.CreateDefault() + .AddService(serviceName: "test-source", serviceVersion: "1.0.0")) + .AddInMemoryExporter(exportedItems) + .Build(); + + var hookUnderTest = TracingHook.Builder().CreateActivities(createSpans).Build(); + var featureKey = "feature-key"; + var context = Context.New("foo"); + + var rootActivity = testSource.StartActivity("root-activity"); + + var evalContext1 = new EvaluationSeriesContext(featureKey, context, LdValue.Of(true), "LdClient.BoolVariation"); + var data1 = hookUnderTest.BeforeEvaluation(evalContext1, new SeriesDataBuilder().Build()); + hookUnderTest.AfterEvaluation(evalContext1, data1, + new EvaluationDetail(LdValue.Of(true), 0, EvaluationReason.FallthroughReason)); + + var evalContext2 = new EvaluationSeriesContext(featureKey, context, LdValue.Of("default"), "LdClient.StringVariation"); + var data2 = hookUnderTest.BeforeEvaluation(evalContext2, new SeriesDataBuilder().Build()); + hookUnderTest.AfterEvaluation(evalContext2, data2, + new EvaluationDetail(LdValue.Of("default"), 0, EvaluationReason.FallthroughReason)); + + rootActivity.Stop(); + + var items = exportedItems.ToList(); + + if (createSpans) + { + // If we're creating spans, since there is an existing root span, we should see the children parented + // to it. + Assert.Equal(3, items.Count); + Assert.Equal("LdClient.BoolVariation", items[0].OperationName); + Assert.Equal("LdClient.StringVariation", items[1].OperationName); + Assert.Equal("root-activity", items[2].OperationName); + Assert.Equal(items[2].SpanId, items[0].ParentSpanId); + } + else + { + // Otherwise, there should only be the root span that was already created. + Assert.Single(items); + Assert.Equal("root-activity", items[0].OperationName); + Assert.Null(items[0].Parent); + } + } + + [Theory] + [InlineData(true)] + [InlineData(false)] + public void TracingHookIncludesVariant(bool includeVariant) + { + ICollection exportedItems = new Collection(); + + var testSource = new ActivitySource("test-source", "1.0.0"); + + var tracerProvider = OpenTelemetry.Sdk.CreateTracerProviderBuilder() + .AddSource("test-source") + .SetResourceBuilder( + ResourceBuilder.CreateDefault() + .AddService(serviceName: "test-source", serviceVersion: "1.0.0")) + .AddInMemoryExporter(exportedItems) + .Build(); + + var hookUnderTest = TracingHook.Builder().IncludeVariant(includeVariant).Build(); + var featureKey = "feature-key"; + var context = Context.New("foo"); + + var rootActivity = testSource.StartActivity("root-activity"); + + var evalContext1 = new EvaluationSeriesContext(featureKey, context, LdValue.Of(true), "LdClient.BoolVariation"); + var data1 = hookUnderTest.BeforeEvaluation(evalContext1, new SeriesDataBuilder().Build()); + hookUnderTest.AfterEvaluation(evalContext1, data1, + new EvaluationDetail(LdValue.Of(true), 0, EvaluationReason.FallthroughReason)); + + var evalContext2 = new EvaluationSeriesContext(featureKey, context, LdValue.Of("default"), "LdClient.StringVariation"); + var data2 = hookUnderTest.BeforeEvaluation(evalContext2, new SeriesDataBuilder().Build()); + hookUnderTest.AfterEvaluation(evalContext2, data2, + new EvaluationDetail(LdValue.Of("default"), 0, EvaluationReason.FallthroughReason)); + + rootActivity.Stop(); + + var items = exportedItems.ToList(); + + Assert.Single(items); + Assert.Equal("root-activity", items[0].OperationName); + + if (includeVariant) + { + // The idea is to check that the span has two events attached to it, and those events contain the feature + // flag variants. It's awkward to check because we don't know the exact order of the events or those + // events' tags. + var events = items[0].Events; + Assert.Single(events.Where(e => + e.Tags.Contains(new KeyValuePair("feature_flag.variant", "true")))); + Assert.Single(events.Where(e => + e.Tags.Contains(new KeyValuePair("feature_flag.variant", "\"default\"")))); + } + else + { + // If not including the variant, then we shouldn't see any variant tag on any events. + Assert.All(items, i => i.Events.All(e => e.Tags.All(kvp => kvp.Key != "feature_flag.variant"))); + } + } + } +} diff --git a/release-please-config.json b/release-please-config.json index c94e2835..ff5d1c0a 100644 --- a/release-please-config.json +++ b/release-please-config.json @@ -1,14 +1,22 @@ { - "bootstrap-sha": "63aca1881c13d09b6be3baf44ddfbe78cf71632c", + "bootstrap-sha": "e3bc4e0889e63e488476cacf726b3b541d174b94", + "include-component-in-tag": true, "packages": { - ".": { + "pkgs/sdk/server": { "release-type": "simple", "bump-minor-pre-major": true, - "versioning": "default", "include-v-in-tag": false, "include-component-in-tag": false, "extra-files": [ - "src/LaunchDarkly.ServerSdk/LaunchDarkly.ServerSdk.csproj" + "pkgs/sdk/server/src/LaunchDarkly.ServerSdk.csproj" + ] + }, + "pkgs/telemetry": { + "release-type": "simple", + "bump-minor-pre-major": true, + "include-v-in-tag": false, + "extra-files": [ + "pkgs/sdk/server/src/LaunchDarkly.ServerSdk.Telemetry.csproj" ] } }