1DS C++ SDK
Перейти к файлу
Yulin Li a911a365f7
Merge branch 'main' into yulin/shared-lib
2024-10-12 15:05:16 +08:00
.github Upgrade mockito test dependency to be compatible with new Java version (#1298) 2024-09-05 07:21:56 -07:00
Solutions Remove _CRT_SECURE_NO_WARNINGS macro usage (#1264) 2024-04-16 15:59:54 -07:00
docker Add Docker File for RHEL 9 support. (#1135) 2023-04-22 18:55:21 -07:00
docs Introduce memset_s in sqlite3 (#1286) 2024-07-23 22:23:32 -07:00
examples Remove _CRT_SECURE_NO_WARNINGS macro usage in example code, fix any errors arising from disabling this. (#1265) 2024-04-22 08:14:42 -07:00
lib Merge branch 'main' into yulin/shared-lib 2024-10-12 15:05:16 +08:00
sqlite Introduce memset_s in sqlite3 (#1286) 2024-07-23 22:23:32 -07:00
sqliteUWP Move to PlatformToolset variable (#882) 2021-05-27 16:41:16 -07:00
tests Merge branch 'main' into yulin/shared-lib 2024-10-12 15:05:16 +08:00
third_party [Fix: 1081] upgrade googletest to v1.12.1 (#1082) 2023-01-06 15:56:51 -08:00
tools Remove unmaintained tool OneDSInspector (#1273) 2024-05-10 20:57:18 -07:00
wrappers Remove go wrapper (#1268) 2024-04-30 16:38:12 -07:00
zlib enable MultiProcessorCompilation to speed up compilation (#916) 2021-08-25 16:43:21 +08:00
.clang-format Adjust the style to be in alignment with what the rest of code is 2019-10-23 16:26:04 -07:00
.gitattributes License cleanup + license clean-up scripts: 2020-10-07 00:51:29 -07:00
.gitignore Update .gitignore with all *.ses 2020-09-24 17:37:40 -07:00
.gitmodules Remove krabsetw submodule commit (#1003) 2022-03-19 17:12:05 -07:00
.markdownlint.json Further repo cleanup for OSS: remove unnecessary details 2020-10-22 01:52:49 -07:00
.readthedocs.yaml fix (#999) 2022-04-05 09:52:20 -07:00
Android.bp Add Android.bp to support Android platform builds (#966) 2021-12-07 11:14:46 -08:00
CMakeLists.txt Introduce memset_s in sqlite3 (#1286) 2024-07-23 22:23:32 -07:00
CODE_OF_CONDUCT.md Create CODE_OF_CONDUCT.md 2021-02-10 11:51:15 -08:00
LICENSE License cleanup + license clean-up scripts: 2020-10-07 00:51:29 -07:00
README.md Update "Getting started" section. (#1284) 2024-06-26 11:41:59 -07:00
RunOACR.bat Some recent regression in GitHub actions (NOT our infra!!) is causing all of our Windows builds to fail. 2019-10-24 12:43:35 -07:00
SECURITY.md markdownlint cleanup 2020-10-22 01:54:19 -07:00
azure-pipelines.yml OSS clean-up: 2020-08-13 22:30:45 -07:00
build-Win32Debug.bat Project stopped building with MSBuild 16.10.0 (#883) 2021-05-28 09:10:18 -07:00
build-Win32Release.bat Project stopped building with MSBuild 16.10.0 (#883) 2021-05-28 09:10:18 -07:00
build-all-v142.bat Remove setup-buildtools.cmd from vs2019 loop ( since it hangs :-/ ) 2021-03-22 13:04:00 -07:00
build-all-v143.bat Add build script for vs2022 (#1041) 2022-07-21 13:24:18 -07:00
build-all.bat Include CSharp sample in build script and add it to CodeQL list (#1278) 2024-05-23 08:56:01 -07:00
build-android.cmd Upgrade android libraries (#1103) 2023-05-04 13:15:49 +03:00
build-clang.sh Microsoft Applications Telemetry SDK for C/C++ - v3.2 (April 2019) 2019-04-02 15:03:34 -07:00
build-cmake-clang-vs2017.cmd Point back to latest lib/modules master 2020-08-17 10:59:11 -07:00
build-cmake-clang-vs2019.cmd Point back to latest lib/modules master 2020-08-17 10:59:11 -07:00
build-docker.cmd Update build-docker.cmd 2020-05-02 11:30:59 -07:00
build-docker.sh Update docker scripts for Linux (#64) 2019-08-24 10:04:26 -07:00
build-gtest.sh update scripts/cmake files to imporve shared lib build propcess 2023-01-13 17:08:06 +08:00
build-ios.sh Fix build scripts and add visionOS support (#1279) 2024-05-29 14:03:49 -07:00
build-rhel.sh Microsoft Applications Telemetry SDK for C/C++ - v3.2 (April 2019) 2019-04-02 15:03:34 -07:00
build-tests-ios.sh Build gtest/gmock for iOS (#346) 2020-05-06 11:58:41 -07:00
build-tests.cmd [Fix: 1081] upgrade googletest to v1.12.1 (#1082) 2023-01-06 15:56:51 -08:00
build-tests.sh revert 2023-01-21 16:21:30 +08:00
build-win.ps1 Fix build scripts to support CntOS8 and Windows build with VS2019 (any) (#1006) 2022-04-05 20:25:50 -07:00
build-win10-compact.bat Project stopped building with MSBuild 16.10.0 (#883) 2021-05-28 09:10:18 -07:00
build-win10-min.bat Project stopped building with MSBuild 16.10.0 (#883) 2021-05-28 09:10:18 -07:00
build-x64Debug.bat Project stopped building with MSBuild 16.10.0 (#883) 2021-05-28 09:10:18 -07:00
build-x64Release.bat Project stopped building with MSBuild 16.10.0 (#883) 2021-05-28 09:10:18 -07:00
build-xamarin.sh Add missing methods and properties to obj-c wrapper with corresponding Xamarin bindings (#750) 2021-01-07 09:29:54 -08:00
build.sh Merge branch 'main' into yulin/shared-lib 2024-05-29 14:06:23 -07:00
install.sh Verified the flow on Linux for static and shared library. Use new Google Test for Ubuntu 20.04 (old one no longer compiles) 2020-09-22 01:16:29 -07:00
mat-sdk.spec.in Update version for 2021 to v3.5 2021-01-19 14:09:52 -08:00
test-all.cmd Some recent regression in GitHub actions (NOT our infra!!) is causing all of our Windows builds to fail. 2019-10-24 12:43:35 -07:00

README.md

1DS C/C++ SDK

spellcheck

1DS C/C++ SDK enables cross-platform telemetry collection from various Microsoft products. It enables data / telemetry upload to Collector++.

1DS (One Data Strategy), also known as One Observability, is a cross-org initiative with five teams across the company coming together to unify multiple telemetry efforts at Microsoft. This includes the teams that built Asimov, Aria, Shared Data Platform, Geneva, OMS, Azure Monitor, and Visual Studio App Center. We aim to create a unified data collection, ingestion, pipeline, and set of tools for key scenarios for the entire company.

Collector++ is the externally-facing destination end-point where telemetry data is uploaded to that subsequently routes the data to Microsoft internal data pipeline.

Getting Started

New customer?

  • The 1DS C/C++ SDK is designed for Microsoft products to send data to public-facing end-points which route to Microsoft's internal data pipeline. It is not meant to be used outside of Microsoft products and is open-sourced to demonstrate best practices and to be transparent about what is being collected.

  • Users with Microsoft Organization GH account, please refer to the link here for internal community discussion channels.

Need support?

  • Microsoft products using SDK may use GitHub issues as the communication channel for both feature requests and issues.

Want to Contribute?

Release policy:

The SDK is released as a source package on need basis. There is no plan to release prebuilt binaries.

Build

Platform specific build instructions:

Other resources to learn how to setup the build system:

  • Review how our cross-platform build system is implemented using GitHub Actions infrastructure.
  • Check the build scripts located in workspace root.

Build Environments

Operating System Compiler
Mac OS X 10.11.6 Clang Xcode 8.3
Mac OS X 10.12.6 Clang Xcode 9.0, 9.1
Mac OS X 10.13.3 Clang Xcode 9.2, 9.3, 10.0, 10.1
Raspbian GNU/Linux 8 (jessie) GCC 4.9.2 (armv7l)
Ubuntu 14.04.x LTS GCC 5.x.x
Ubuntu 16.04 LTS GCC 5.x.x, GCC 5.x.x (armv7l)
Ubuntu 18.04 LTS GCC 7.5.x
Windows 10 Android Studio/Gradle
Windows Server 2016 Visual Studio 2017 (vc141)
Windows Server 2019 Visual Studio 2019 (vc142)

Target Platforms

Target Platform Supported Covered by CI
Android
iOS 10+ (simulator)
iOS 10+ (arm64, arm64e)
Linux (x86, x64, arm, aarch64)
Mac OS X 10.11+
Mac OS X (latest)
Ubuntu 14.04.x LTS
Ubuntu 16.04.x LTS
Ubuntu 18.04.x LTS
Ubuntu 20.04.x LTS
Ubuntu (latest)
Windows 7.1
Windows 8.1
Windows 10.x
Windows Server 2012
Windows Server 2016
Windows Server 2019
  • Supported - these platforms are known to work well with the SDK in production.
  • Covered by CI - these platforms are tested as part of CI.

Test

There are two sets of tests available:

  • tests/unittests - unit tests that verify operation of each individual component.
  • tests/functests - functional tests that verify customer-facing APIs and features, they also cover the flow of data to Collector++.

These tests use Google Test / Google Mock framework and get built alongside the SDK. Launch functests and unittests binary executables to capture the test results.

Note:

  • Please refer to the supported platforms, anything not in the list should be treated as a feature request.
  • Only C and C++ API surface is supported - any other language wrappers are provided as-is, and not supported.
  • Build issues are in general out of the support scope due to the unlimited number of build flags combinations.

Versioning

This library follows Semantic Versioning.

License

By contributing to 1DS C++ SDK repository, you agree that your contributions will be licensed under Apache License 2.0.