-
Notifications
You must be signed in to change notification settings - Fork 91
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* add migration script * Adding new migrate script that is all-inclusive.. * Updates to logging and molecule * New single All-inclusive migrate script is now migrate.ps1 * Renamed script, added falconcid, updated readme * Updated molecule * Update readme + fix ps lint --------- Co-authored-by: Carlos Matos <carlos.matos@crowdstrike.com>
- Loading branch information
1 parent
65940eb
commit 51136e4
Showing
7 changed files
with
1,394 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,23 @@ | ||
********************************* | ||
Vagrant driver installation guide | ||
********************************* | ||
|
||
Requirements | ||
============ | ||
|
||
* Vagrant | ||
* Virtualbox, Parallels, VMware Fusion, VMware Workstation or VMware Desktop | ||
|
||
Install | ||
======= | ||
|
||
Please refer to the `Virtual environment`_ documentation for installation best | ||
practices. If not using a virtual environment, please consider passing the | ||
widely recommended `'--user' flag`_ when invoking ``pip``. | ||
|
||
.. _Virtual environment: https://virtualenv.pypa.io/en/latest/ | ||
.. _'--user' flag: https://packaging.python.org/tutorials/installing-packages/#installing-to-the-user-site | ||
|
||
.. code-block:: bash | ||
|
||
$ pip install 'molecule_vagrant' |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,18 @@ | ||
--- | ||
- name: Converge | ||
hosts: all | ||
gather_facts: false | ||
tasks: | ||
- name: Run Migrate Script | ||
ansible.builtin.script: > | ||
../../powershell/migrate/falcon_windows_migrate.ps1 | ||
-NewFalconClientId "{{ lookup('env', 'FALCON_CLIENT_ID') }}" | ||
-NewFalconClientSecret "{{ lookup('env', 'FALCON_CLIENT_SECRET') }}" | ||
-OldFalconClientId "{{ lookup('env', 'FALCON_CLIENT_ID') }}" ` | ||
-OldFalconClientSecret "{{ lookup('env', 'FALCON_CLIENT_SECRET') }}" | ||
-NewFalconCloud "us-2" | ||
-OldFalconCloud "us-2" | ||
-ProvToken "{{ lookup('env', 'FALCON_PROV_TOKEN') }}" | ||
-RemoveHost | ||
-Tags "migrate1,migrate2" | ||
-FalconTags "tag1,tag2" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,37 @@ | ||
--- | ||
dependency: | ||
name: galaxy | ||
driver: | ||
name: vagrant | ||
provider: | ||
name: virtualbox | ||
platforms: | ||
- name: falcon | ||
box: "jborean93/${MOLECULE_DISTRO:-WindowsServer2019}" | ||
box_version: 1.0.0 | ||
memory: 8192 | ||
cpus: 3 | ||
provisioner: | ||
name: ansible | ||
config_options: | ||
defaults: | ||
stdout_callback: yaml | ||
inventory: | ||
host_vars: | ||
falcon: | ||
ansible_become: False | ||
ansible_user: vagrant | ||
ansible_password: vagrant | ||
ansible_connection: winrm | ||
ansible_winrm_transport: ntlm | ||
ansible_winrm_server_cert_validation: ignore | ||
ansible_port: 55986 | ||
scenario: | ||
test_sequence: | ||
- dependency | ||
- syntax | ||
- create | ||
- prepare | ||
- converge | ||
- side_effect | ||
- verify |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,12 @@ | ||
--- | ||
- name: Prepare | ||
hosts: all | ||
gather_facts: false | ||
tasks: | ||
- name: Run Install Script | ||
ansible.builtin.script: > | ||
../../powershell/install/falcon_windows_install.ps1 | ||
-FalconClientId "{{ lookup('env', 'FALCON_CLIENT_ID') }}" | ||
-FalconClientSecret "{{ lookup('env', 'FALCON_CLIENT_SECRET') }}" | ||
-ProvToken "{{ lookup('env', 'FALCON_PROV_TOKEN') }}" | ||
-Tags "existing1,existing2" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,15 @@ | ||
--- | ||
- name: Verify | ||
hosts: all | ||
tasks: | ||
- name: Check status of Falcon Sensor | ||
ansible.windows.win_command: sc.exe query csagent | ||
register: win_status | ||
|
||
- name: Verify Falcon Sensor is installed and running | ||
ansible.builtin.assert: | ||
that: "'RUNNING' in win_status.stdout" | ||
|
||
# TODO: Create task to verify Tags | ||
# Sensor Tags should be: falcon,install,molecule | ||
# Grouping Tags should be: FalconGroupingTags/molecule |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,148 @@ | ||
# Falcon Powershell Sensor Migration Script | ||
|
||
A versatile PowerShell script for host migration between Falcon cloud tenants, such as transitioning from US-1 to EU-1. | ||
|
||
> Can also be used to migrate a sensor from one CID to another within the same cloud. | ||
## Requirements | ||
|
||
- PowerShell 3.0 or higher | ||
|
||
The following **API scopes** are required: | ||
|
||
- **Sensor Download** [read] | ||
- **Host** [read,write] | ||
- **Sensor update policies** [write] | ||
|
||
## What Does It Do? | ||
|
||
This script streamlines the process of migrating a sensor from one CrowdStrike Falcon cloud tenant to another, such as transitioning from US-1 to US-2. It handles the removal and installation of the sensor in the new cloud while maintaining Falcon and Sensor tags throughout the migration. If an error arises during the migration, a recovery log is available to track the process and facilitate resumption of the migration. | ||
|
||
The migration script effectively transfers the following settings: | ||
|
||
- Sensor Tags (locally added tags on the sensor) | ||
- Falcon Tags (tags assigned to the sensor in the Falcon console) | ||
|
||
Additionally, it can assign new tags to the sensor during migration as well as give you the option to remove the old host from the UI after uninstallation. | ||
|
||
Throughout the migration, errors and modifications are logged to a default location, which can be altered as needed: `Windows\Temp\csfalcon_migration_yyyy-MM-dd_HH-mm-ss.log`. | ||
|
||
## Usage | ||
|
||
The script must be run as an administrator on the target machine in order for the migration to complete | ||
successfully. | ||
|
||
Script options can be passed as parameters or defined in the param() block. Default values are listed in | ||
the parameter descriptions: | ||
|
||
```terminal | ||
Falcon and Sensor tags are migrated to the new installation. | ||
.PARAMETER NewFalconClientId | ||
CrowdStrike Falcon OAuth2 API Client Id for the new Cloud [Required] | ||
.PARAMETER NewFalconClientSecret | ||
CrowdStrike Falcon OAuth2 API Client Secret for the new Cloud [Required] | ||
.PARAMETER OldFalconClientId | ||
CrowdStrike Falcon OAuth2 API Client Id for the old cloud [Required] | ||
.PARAMETER OldFalconClientSecret | ||
CrowdStrike Falcon OAuth2 API Client Secret for the old cloud [Required] | ||
.PARAMETER NewFalconCloud | ||
CrowdStrike Falcon OAuth2 API Hostname for the new cloud [default: 'autodiscover'] | ||
.PARAMETER OldFalconCloud | ||
CrowdStrike Falcon OAuth2 API Hostname for the old cloud [default: 'autodiscover'] | ||
.PARAMETER NewFalconCid | ||
Manually specify CrowdStrike Customer ID (CID) for the new cloud [default: $null] | ||
.PARAMETER NewMemberCid | ||
Member CID, used only in multi-CID ("Falcon Flight Control") configurations and with a parent management CID for the new cloud. | ||
.PARAMETER OldMemberCid | ||
Member CID, used only in multi-CID ("Falcon Flight Control") configurations and with a parent management CID for the old cloud. | ||
.PARAMETER SensorUpdatePolicyName | ||
Sensor Update Policy name to check for assigned sensor version [default: 'platform_default'] | ||
.PARAMETER InstallParams | ||
Sensor installation parameters, without your CID value ['/install /quiet /noreboot' if left undefined] | ||
.PARAMETER LogPath | ||
Script log location ['Windows\Temp\csfalcon_migration_yyyy-MM-dd_HH-mm-ss.log' if left undefined] | ||
.PARAMETER DeleteInstaller | ||
Delete sensor installer package when complete [default: $true] | ||
.PARAMETER DeleteUninstaller | ||
Delete sensor uninstaller package when complete [default: $true] | ||
.PARAMETER DeleteScript | ||
Delete script when complete [default: $false] | ||
.PARAMETER ProvToken | ||
Provisioning token to use for sensor installation [default: $null] | ||
.PARAMETER ProvWaitTime | ||
Time to wait, in seconds, for sensor to provision [default: 1200] | ||
.PARAMETER Tags | ||
A comma-separated list of sensor grouping tags to apply to the host in addition to any pre-existing tags [default: $null] | ||
.PARAMETER FalconTags | ||
A comma-separated list of falcon grouping tags to apply to the host in addition to any pre-existing tags [default: $null] | ||
.PARAMETER MaintenanceToken | ||
Sensor uninstall maintenance token. If left undefined, the script will attempt to retrieve the token from the API assuming the FalconClientId|FalconClientSecret are defined. | ||
.PARAMETER UninstallParams | ||
Sensor uninstall parameters ['/uninstall /quiet' if left undefined] | ||
.PARAMETER UninstallTool | ||
Sensor uninstall tool, local installation cache or CS standalone uninstaller ['installcache' if left undefined] | ||
.PARAMETER RemoveHost | ||
Remove host from CrowdStrike Falcon | ||
.PARAMETER SkipTags | ||
Opt in/out of migrating tags. Tags passed to the Tags flag will still be added. | ||
``` | ||
|
||
### Example 1 | ||
|
||
A simple migration from US-1 to US-2 including sensor tags and falcon tags: | ||
|
||
```pwsh | ||
.\falcon_windows_migrate.ps1 ` | ||
-NewFalconClientId 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx' ` | ||
-NewFalconClientSecret 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx' ` | ||
-OldFalconClientId 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx' ` | ||
-OldFalconClientSecret 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx' ` | ||
-NewFalconCloud "us-2" ` | ||
-OldFalconCloud "us-1" | ||
``` | ||
|
||
### Example 2 | ||
|
||
Migrate from US-1 to EU-1, remove the old host from the UI and add a new sensor tag: | ||
|
||
```pwsh | ||
.\falcon_windows_migrate.ps1 ` | ||
-NewFalconClientId 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx' ` | ||
-NewFalconClientSecret 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx' ` | ||
-OldFalconClientId 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx' ` | ||
-OldFalconClientSecret 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx' ` | ||
-NewFalconCloud "eu-1" ` | ||
-OldFalconCloud "us-1" ` | ||
-RemoveHost ` | ||
-Tags "NewTag,NewTag2" | ||
``` | ||
|
||
### Example 3 | ||
|
||
Migrate from US-2 to EU-1, use a provisioning token and add a new falcon tag to the sensor: | ||
|
||
```pwsh | ||
.\falcon_windows_migrate.ps1 ` | ||
-NewFalconClientId 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx' ` | ||
-NewFalconClientSecret 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx' ` | ||
-OldFalconClientId 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx' ` | ||
-OldFalconClientSecret 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx' ` | ||
-NewFalconCloud "eu-1" ` | ||
-OldFalconCloud "us-2" ` | ||
-ProvToken 'xxxxxxxx' ` | ||
-FalconTags "NewFalconTag" | ||
``` | ||
|
||
### Example 4 | ||
|
||
Migrate from one CID to another within the same cloud: | ||
|
||
```pwsh | ||
.\falcon_windows_migrate.ps1 ` | ||
-NewFalconClientId 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx' ` | ||
-NewFalconClientSecret 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx' ` | ||
-OldFalconClientId 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx' ` | ||
-OldFalconClientSecret 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx' ` | ||
-NewFalconCloud "eu-1" ` | ||
-OldFalconCloud "eu-1" ` | ||
``` |
Oops, something went wrong.