From aab19b1fc76a36009abac63da5945eedc6a33f20 Mon Sep 17 00:00:00 2001
From: Jonathan Algar <93204286+jonathanalgar@users.noreply.github.com>
Date: Tue, 5 Dec 2023 14:07:10 +0000
Subject: [PATCH] Add ACI guidance back to seperate FAQ.md
---
FAQ.md | 42 ++++++++++++++++++++++++++++++++++++++++++
README.md | 4 +++-
2 files changed, 45 insertions(+), 1 deletion(-)
create mode 100644 FAQ.md
diff --git a/FAQ.md b/FAQ.md
new file mode 100644
index 0000000..c40f48f
--- /dev/null
+++ b/FAQ.md
@@ -0,0 +1,42 @@
+
+
+
+OutSystems Cloud Connector
+
+
+![MIT][s0]
+
+[s0]: https://img.shields.io/badge/license-MIT-blue.svg
+
+## FAQs
+
+### How do I run `outsystemscc` on Azure Container Instances?
+
+The command to create a new container with the [Azure CLI](https://learn.microsoft.com/en-us/cli/azure/install-azure-cli) for the [Usage section example](README.md#usage) is:
+
+ az container create \
+ -g [ResourceGroupName] \
+ --name [ContainerName] \
+ --image ghcr.io/outsystems/outsystemscc \
+ --command-line '/app/outsystemscc --header "token: N2YwMDIxZTEtNGUzNS1jNzgzLTRkYjAtYjE2YzRkZGVmNjcy" https://customername.outsystems.app/sq_f5696918-3a8c-4da8-8079-ef768d5479fd R:8081:192.168.0.3:8393'
+
+The key parameters used in the command:
+
+* `-g [ResourceGroupName]`: Specifies the name of the resource group where the container instance will be created.
+* `--name [ContainerName]`: Specifies the name of the container instance.
+* `--image ghcr.io/outsystems/outsystemscc`: Specifies the Docker image to use for the container instance.
+* `--command-line '...'`: Specifies the command line to run in the container. This command starts the `outsystemscc` service with the specified header token, server URL, and remote connection details.
+
+Ensure to replace `[ResourceGroupName]`, `[ContainerName]`, and the values in the `--command-line` parameter with your actual values.
+
+#### Network configuration
+
+* **Outbound Access to Internet:** Ensure that the Azure Resource Group in which you are deploying `outsystemscc` has outbound access to the Internet with no greater restriction than specified in [Firewall setup](#firewall-setup). This is crucial for `outsystemscc` to communicate with your ODC organization. You may need to configure your Network Security Groups (NSGs), Azure Firewall, or whichever network security solution you have in place to allow outbound connections.
+
+* **Access to Endpoints:** Additionally, ensure that the network configuration allows traffic from the Azure Container Instance to the internal endpoint(s) you wish to connect to. This may involve configuring your Virtual Network (VNet), Subnets, and Network Security Groups (NSGs) to allow the necessary traffic. If there are firewalls or other network devices blocking traffic, you'll need to configure them accordingly.
+
+* **Testing Connectivity:** It's a good practice to test the network connectivity before deploying `outsystemscc`. You can use tools like [Azure Network Watcher](https://docs.microsoft.com/en-us/azure/network-watcher/network-watcher-monitoring-overview) or even basic network troubleshooting tools like ping and traceroute to verify connectivity.
+
+* **Monitoring and Logging:** Implement monitoring and logging to get insights into the network traffic and to troubleshoot any connectivity issues. Azure provides various monitoring and logging tools like [Azure Monitor](https://docs.microsoft.com/en-us/azure/azure-monitor/overview) and [Azure Log Analytics](https://docs.microsoft.com/en-us/azure/azure-monitor/log-query/log-analytics-tutorial) which can be invaluable for diagnosing network-related issues.
+
+### **[⏎ Back to README](./README.md)**
\ No newline at end of file
diff --git a/README.md b/README.md
index ede6f8f..58962b7 100644
--- a/README.md
+++ b/README.md
@@ -107,6 +107,8 @@ Use the **Token** and **Address** to form the `outsystemscc` command to run. For
In this example, you create a tunnel to the endpoint `192.168.0.3:8393`, a REST API service running on IP address `192.168.0.3`. The endpoint is available to consume by apps running in the connected stage at `secure-gateway:8081`.
+> :bulb: If you want to run `outsystemscc` on Azure Container Instances, [see the FAQs](FAQ.md#how-do-i-run-outsystemscc-on-azure-container-instances) for specific guidance.
+
You can create a tunnel to connect multiple endpoints to the same Private Gateway. To do this, run multiple instances of `outsystemscc` or pass in multiple remotes (`R:::`) to the same instance. In the latter case, for example:
outsystemscc \
@@ -203,4 +205,4 @@ If your organization uses a centralized log management product, see its document
## 5. License [Top ▲](#table-of-contents)
-[MIT](https://github.com/outsystems/cloud-connector/blob/master/LICENSE) © OutSystems
+[MIT](https://github.com/outsystems/cloud-connector/blob/master/LICENSE) © OutSystems
\ No newline at end of file