From ed4c05d3c4bae851e13e453ced04b0132269448d Mon Sep 17 00:00:00 2001
From: Jaanus Sellin
Date: Fri, 27 Sep 2024 13:46:12 +0300
Subject: [PATCH] feat: add production snippets and resources (#8286)
Skipped .NET and Android because they are not ready. Also swift does not
support env variables, so skipped for now.
Added all rest.
---
.../onboarding/dialog/SdkConnected.tsx | 6 ++---
.../onboarding/dialog/snippets/flutter.md | 18 ++++++++++++++
.../onboarding/dialog/snippets/go.md | 24 +++++++++++++++++++
.../onboarding/dialog/snippets/java.md | 15 ++++++++++++
.../onboarding/dialog/snippets/javascript.md | 13 ++++++++++
.../onboarding/dialog/snippets/nodejs.md | 2 +-
.../onboarding/dialog/snippets/php.md | 13 ++++++++++
.../onboarding/dialog/snippets/python.md | 16 +++++++++++++
.../onboarding/dialog/snippets/react.md | 14 +++++++++++
.../onboarding/dialog/snippets/ruby.md | 15 +++++++++++-
.../onboarding/dialog/snippets/rust.md | 19 +++++++++++++++
.../onboarding/dialog/snippets/svelte.md | 16 +++++++++++--
.../onboarding/dialog/snippets/vue.md | 13 +++++++++-
13 files changed, 176 insertions(+), 8 deletions(-)
diff --git a/frontend/src/component/onboarding/dialog/SdkConnected.tsx b/frontend/src/component/onboarding/dialog/SdkConnected.tsx
index b80258bf0f..cf40151719 100644
--- a/frontend/src/component/onboarding/dialog/SdkConnected.tsx
+++ b/frontend/src/component/onboarding/dialog/SdkConnected.tsx
@@ -45,9 +45,9 @@ export const SdkConnected: FC = ({ sdk }) => {
Production settings
- In order to validate the connection, we changed some
- settings that you might want to revert. We recommend the
- following default settings.
+ We updated the Unleash code snippet to be production-ready.
+ We recommend applying the following new settings to avoid
+ exposing the API key and to follow best practices.
{productionSnippet}
diff --git a/frontend/src/component/onboarding/dialog/snippets/flutter.md b/frontend/src/component/onboarding/dialog/snippets/flutter.md
index 43bea5e18b..76ab182e9c 100644
--- a/frontend/src/component/onboarding/dialog/snippets/flutter.md
+++ b/frontend/src/component/onboarding/dialog/snippets/flutter.md
@@ -20,3 +20,21 @@ Timer.periodic(Duration(seconds: 1), (Timer timer) {
print('Flag is ${unleash.isEnabled("") ? "enabled" : "disabled"}');
});
```
+---
+```dart
+import 'package:unleash_proxy_client_flutter/unleash_proxy_client_flutter.dart';
+import 'dart:async';
+import 'dart:io';
+
+final unleash = UnleashClient(
+ url: Uri.parse(''),
+ clientKey: Platform.environment['UNLEASH_CLIENT_KEY']!,
+ appName: 'unleash-onboarding-flutter');
+
+unleash.start();
+```
+
+---
+- [SDK repository with documentation](https://github.com/Unleash/unleash_proxy_client_flutter)
+- [Flutter example with CodeSandbox](https://github.com/Unleash/unleash-sdk-examples/tree/main/Flutter)
+- [A/B Testing in Flutter using Unleash and Mixpanel](https://docs.getunleash.io/feature-flag-tutorials/flutter/a-b-testing)
diff --git a/frontend/src/component/onboarding/dialog/snippets/go.md b/frontend/src/component/onboarding/dialog/snippets/go.md
index 63170c00cf..b59f8175ee 100644
--- a/frontend/src/component/onboarding/dialog/snippets/go.md
+++ b/frontend/src/component/onboarding/dialog/snippets/go.md
@@ -28,3 +28,27 @@ func main() {
}
}
```
+
+---
+```go
+import (
+ "github.com/Unleash/unleash-client-go/v3"
+ "net/http"
+ "time"
+)
+
+func init() {
+ unleash.Initialize(
+ unleash.WithListener(&unleash.DebugListener{}),
+ unleash.WithAppName("unleash-onboarding-golang"),
+ unleash.WithUrl(""),
+ unleash.WithCustomHeaders(http.Header{
+ "Authorization": {os.Getenv("UNLEASH_API_KEY")},
+ })
+ )
+}
+```
+
+---
+- [SDK repository with documentation](https://github.com/Unleash/unleash-client-go)
+- [Go SDK example with CodeSandbox](https://github.com/Unleash/unleash-sdk-examples/tree/main/Go)
diff --git a/frontend/src/component/onboarding/dialog/snippets/java.md b/frontend/src/component/onboarding/dialog/snippets/java.md
index ed41182a6f..a0df9e56d9 100644
--- a/frontend/src/component/onboarding/dialog/snippets/java.md
+++ b/frontend/src/component/onboarding/dialog/snippets/java.md
@@ -25,3 +25,18 @@ while (true) {
Thread.sleep(1000);
}
```
+
+---
+```java
+UnleashConfig config = UnleashConfig.builder()
+ .appName("unleash-onboarding-java")
+ .instanceId("unleash-onboarding-instance")
+ .unleashAPI("")
+ .apiKey(System.getenv("UNLEASH_API_KEY"))
+ .build();
+```
+
+---
+- [SDK repository with documentation](https://github.com/Unleash/unleash-client-java)
+- [Java SDK example with CodeSandbox](https://github.com/Unleash/unleash-sdk-examples/tree/main/Java)
+- [How to Implement Feature Flags in Java](https://docs.getunleash.io/feature-flag-tutorials/java)
diff --git a/frontend/src/component/onboarding/dialog/snippets/javascript.md b/frontend/src/component/onboarding/dialog/snippets/javascript.md
index d575ebfbef..8f68dce50a 100644
--- a/frontend/src/component/onboarding/dialog/snippets/javascript.md
+++ b/frontend/src/component/onboarding/dialog/snippets/javascript.md
@@ -20,3 +20,16 @@ setInterval(() => {
console.log('Is enabled', unleash.isEnabled(''));
}, 1000);
```
+---
+```js
+const unleash = new UnleashClient({
+ url: '',
+ clientKey: process.env.UNLEASH_API_TOKEN,
+ appName: 'unleash-onboarding-javascript',
+});
+unleash.start();
+```
+
+---
+- [SDK repository with documentation](https://github.com/Unleash/unleash-proxy-client-js)
+- [JavaScript SDK example with CodeSandbox](https://github.com/Unleash/unleash-sdk-examples/tree/main/JavaScript)
diff --git a/frontend/src/component/onboarding/dialog/snippets/nodejs.md b/frontend/src/component/onboarding/dialog/snippets/nodejs.md
index 5ea2523b1e..2580de4e53 100644
--- a/frontend/src/component/onboarding/dialog/snippets/nodejs.md
+++ b/frontend/src/component/onboarding/dialog/snippets/nodejs.md
@@ -32,5 +32,5 @@ const unleash = initialize({
---
- [SDK repository with documentation](https://github.com/Unleash/unleash-client-node)
-- [Node.js SDK example with CodeSandbox](https://github.com/Unleash/unleash-sdk-examples/tree/main/JavaScript)
+- [Node.js SDK example with CodeSandbox](https://github.com/Unleash/unleash-sdk-examples/tree/main/NodeJS)
- [Node.js SDK tutorial](https://dev.to/reeshee/how-to-implement-feature-flags-in-nodejs-using-unleash-3907)
diff --git a/frontend/src/component/onboarding/dialog/snippets/php.md b/frontend/src/component/onboarding/dialog/snippets/php.md
index 636a7fa1b3..120ce6637a 100644
--- a/frontend/src/component/onboarding/dialog/snippets/php.md
+++ b/frontend/src/component/onboarding/dialog/snippets/php.md
@@ -24,3 +24,16 @@ while (true) {
sleep(1);
}
```
+---
+```php
+$unleash = UnleashBuilder::create()
+ ->withAppName('unleash-onboarding-php')
+ ->withAppUrl('')
+ ->withHeader('Authorization', getenv('UNLEASH_API_TOKEN'))
+ ->withInstanceId('unleash-onboarding-instance')
+ ->build();
+```
+
+---
+- [SDK repository with documentation](https://github.com/Unleash/unleash-client-php)
+- [PHP SDK example with CodeSandbox](https://github.com/Unleash/unleash-sdk-examples/tree/main/PHP)
diff --git a/frontend/src/component/onboarding/dialog/snippets/python.md b/frontend/src/component/onboarding/dialog/snippets/python.md
index a1f57952c8..b7ab7b1c2e 100644
--- a/frontend/src/component/onboarding/dialog/snippets/python.md
+++ b/frontend/src/component/onboarding/dialog/snippets/python.md
@@ -20,3 +20,19 @@ while True:
print(client.is_enabled(""))
asyncio.run(asyncio.sleep(1))
```
+---
+```python
+from UnleashClient import UnleashClient
+import asyncio
+import os
+
+client = UnleashClient(
+ url="",
+ app_name="unleash-onboarding-python",
+ custom_headers={'Authorization': os.getenv('UNLEASH_API_TOKEN')}
+```
+
+---
+- [SDK repository with documentation](https://github.com/Unleash/unleash-client-python)
+- [Python SDK example with CodeSandbox](https://github.com/Unleash/unleash-sdk-examples/tree/main/Python)
+- [How to Implement Feature Flags in Python](https://docs.getunleash.io/feature-flag-tutorials/python)
diff --git a/frontend/src/component/onboarding/dialog/snippets/react.md b/frontend/src/component/onboarding/dialog/snippets/react.md
index f78bc46308..7f6cbc43ef 100644
--- a/frontend/src/component/onboarding/dialog/snippets/react.md
+++ b/frontend/src/component/onboarding/dialog/snippets/react.md
@@ -36,3 +36,17 @@ const TestComponent = () => {
return enabled ? 'Flag is enabled' : 'Flag is disabled'
};
```
+---
+```jsx
+const config = {
+ url: '',
+ clientKey: process.env.UNLEASH_API_TOKEN,
+ appName: 'unleash-onboarding-react',
+};
+```
+
+---
+- [SDK repository with documentation](https://github.com/Unleash/proxy-client-react)
+- [React SDK example with CodeSandbox](https://github.com/Unleash/unleash-sdk-examples/tree/main/React)
+- [https://docs.getunleash.io/feature-flag-tutorials/react](https://docs.getunleash.io/feature-flag-tutorials/react)
+
diff --git a/frontend/src/component/onboarding/dialog/snippets/ruby.md b/frontend/src/component/onboarding/dialog/snippets/ruby.md
index fac0eadd52..54d4d3d8e9 100644
--- a/frontend/src/component/onboarding/dialog/snippets/ruby.md
+++ b/frontend/src/component/onboarding/dialog/snippets/ruby.md
@@ -12,7 +12,6 @@ require 'unleash'
custom_http_headers: { 'Authorization': "" },
app_name: 'unleash-onboarding-ruby',
instance_id: 'unleash-onboarding-ruby',
- refresh_interval: 3, # In production use interval of >15s
metrics_interval: 3, # In production use interval of >15s
)
@@ -26,3 +25,17 @@ while true
end
```
+---
+```rb
+@unleash = Unleash::Client.new(
+ url: "",
+ custom_http_headers: { 'Authorization': ENV['UNLEASH_API_TOKEN'] },
+ app_name: 'unleash-onboarding-ruby',
+ instance_id: 'unleash-onboarding-ruby',
+)
+```
+
+---
+- [SDK repository with documentation](https://github.com/Unleash/unleash-client-ruby)
+- [Ruby example with CodeSandbox](https://github.com/Unleash/unleash-sdk-examples/tree/main/Ruby)
+- [How to Implement Feature Flags in Ruby](https://docs.getunleash.io/feature-flag-tutorials/ruby)
diff --git a/frontend/src/component/onboarding/dialog/snippets/rust.md b/frontend/src/component/onboarding/dialog/snippets/rust.md
index de2ab1b346..4ee8646a72 100644
--- a/frontend/src/component/onboarding/dialog/snippets/rust.md
+++ b/frontend/src/component/onboarding/dialog/snippets/rust.md
@@ -50,3 +50,22 @@ async fn main() -> Result<(), Box> {
Ok(())
}
```
+---
+```rust
+let api_token = env::var("UNLEASH_API_TOKEN").expect("UNLEASH_API_TOKEN environment variable not set");
+
+let client: Client = ClientBuilder::default()
+ .interval(5000) // Polling & metrics interval - default 15000 (ms)
+ .into_client(
+ "",
+ "unleash-onboarding-rust",
+ "unleash-onboarding-instance",
+ Some(api_token.to_owned()),
+ )?;
+client.register().await?;
+```
+
+---
+- [SDK repository with documentation](https://github.com/Unleash/unleash-client-rust)
+- [Rust example with CodeSandbox](https://github.com/Unleash/unleash-sdk-examples/tree/main/Rust)
+- [How to Implement Feature Flags in Rust](https://docs.getunleash.io/feature-flag-tutorials/rust)
diff --git a/frontend/src/component/onboarding/dialog/snippets/svelte.md b/frontend/src/component/onboarding/dialog/snippets/svelte.md
index edf2719819..f19dcb990d 100644
--- a/frontend/src/component/onboarding/dialog/snippets/svelte.md
+++ b/frontend/src/component/onboarding/dialog/snippets/svelte.md
@@ -11,8 +11,7 @@ npm install @unleash/proxy-client-svelte
const config = {
url: '',
clientKey: '',
- appName: 'unleash-onboarding-svelte'
- refreshInterval: 5,
+ appName: 'unleash-onboarding-svelte',
metricsInterval: 5,
};
@@ -39,3 +38,16 @@ npm install @unleash/proxy-client-svelte
```
+---
+```svelte
+const config = {
+ url: '',
+ clientKey: import.meta.env.VITE_UNLEASH_API_TOKEN,
+ appName: 'unleash-onboarding-svelte',
+};
+```
+
+---
+- [SDK repository with documentation](https://github.com/Unleash/proxy-client-svelte)
+- [Svelte example with CodeSandbox](https://github.com/Unleash/unleash-sdk-examples/tree/main/Svelte)
+- [How to Implement Feature Flags in SvelteKit](https://docs.getunleash.io/feature-flag-tutorials/sveltekit)
diff --git a/frontend/src/component/onboarding/dialog/snippets/vue.md b/frontend/src/component/onboarding/dialog/snippets/vue.md
index 87b5bee36b..7e559a899c 100644
--- a/frontend/src/component/onboarding/dialog/snippets/vue.md
+++ b/frontend/src/component/onboarding/dialog/snippets/vue.md
@@ -12,7 +12,6 @@ npm install @unleash/proxy-client-vue
url: '',
clientKey: '',
appName: 'unleash-onboarding-vue',
- refreshInterval: 5,
metricsInterval: 5,
}
@@ -37,3 +36,15 @@ npm install @unleash/proxy-client-vue
```
+---
+```svelte
+const config = {
+ url: '',
+ clientKey: import.meta.env.VITE_UNLEASH_API_TOKEN,
+ appName: 'unleash-onboarding-vue',
+}
+```
+
+---
+- [SDK repository with documentation](https://github.com/Unleash/proxy-client-vue)
+- [Vue example with CodeSandbox](https://github.com/Unleash/unleash-sdk-examples/tree/main/Vue)