TeamCity
![]() |
|
You can configure your TeamCity CI/CD pipeline to automatically run a Bright scan with every new build. Once a build is made to the pipeline, Bright initiates security tests and provides all the information that developers need to fix the detected vulnerabilities, without having to leave their development environment. | |
Although it is possible to configure a CI/CD pipeline with the Bright REST API, it is recommended to use the Bright CLI for an easier, more robust configuration of your pipeline. |
Prerequisites
- You have a valid Bright API key (
env.BrightToken
) with the following scopes:scans
,files:write
,org:read
, andprojects:read
. You can create an organization API key or a personal API key. - Register the Repeater in the Bright app and copy the generated
REPEATER_ID
. See Managing Repeaters for more information. - Install and configure the TeamCity CI/CD server and agent.
Note
The Linux Docker deployment of TeamCity is currently not supported — https://youtrack.jetbrains.com/issue/TW-74746.
Step-by-step guide
- Open the TeamCity Administration panel.
- From the left menu, select Projects, and then click + Create project.
data:image/s3,"s3://crabby-images/acca0/acca023a9030f450eb0b3dc0aafc400d76125aa6" alt="create-project.png 1894"
- In the Name field, enter a name for your project (for example, "Bright Scan"), and then click Create.
data:image/s3,"s3://crabby-images/758f5/758f5d980f05b0d684258b67453c1ed1c312e52c" alt="create-bright-project.png 1894"
- In the upper-right corner of the created project page, click Project Home.
data:image/s3,"s3://crabby-images/f45c8/f45c8a23851af5d53483a8bab27a4ca9d6fdb27e" alt="project-home.png 1726"
- Click Create Build Configuration, and then select Manually.
- In the Name field, enter a name for your build configuration (for example, BrightBuild), and then click Create.
data:image/s3,"s3://crabby-images/a702b/a702be57f57fd8895ceb1abbbb608ff61ebc8f9f" alt="create-build.png 1686"
- The New VCS Root form opens. Click Skip to proceed to the next step.
data:image/s3,"s3://crabby-images/f46f3/f46f330bfc664ad89a30e6bf18f67d7e4984425f" alt="skip.png 1895"
- From the left menu, select Parameters, and then click + Add new parameter.
- Create the
endBrightToken
(API key) environment variable:
a) In the Name field, enterendBrightToken
.
b) In the Value filed, enter the value of the token (API key) you have created in the Bright app (see Prerequisites).
c) Click Save.
data:image/s3,"s3://crabby-images/8db3c/8db3c1fd396c56765170dbd04a0beb29c5696e62" alt="7.png 1885"
- Create the
REPEATER_ID
environment variable:
a) In the Name field, enterREPEATER_ID
.
b) In the Value filed, enter the ID of the Repeater you have created in the Bright app (see Prerequisites).
c) Click Save. - From the left menu, select Build Steps.
- On the New Build Step page, do the following:
a) Set Runner Type toNode.js
.
b) Set Run step within Docker container tonode: 14.17.1
.
c) Set Shell script to the following:
npm install @brightsec/cli
cd node_modules/.bin
./bright-cli --version
echo "Starting Repeater"
./bright-cli repeater --id %env.REPEATER_ID% --token %env.BrightToken% &
sleep 10
echo "Starting Brightsec Scan"
SCAN_ID=$(./bright-cli scan:run --token %env.BrightToken% --repeater %env.REPEATER_ID% --name "new scan" --crawler Broken Crystals --smart)
echo "Scan was started with ID Brightsec
sleep 10
echo "Waiting for issues..."
./bright-cli scan:polling --interval 30s --timeout 30m --breakpoint any --token %env.BrightToken% $SCAN_ID
data:image/s3,"s3://crabby-images/44bbe/44bbe0f61debbb05d79b85198bbb7199580a5ffd" alt="8.png 1896"
13. Click **Save**.
- On the top right, click Run to run the build.
data:image/s3,"s3://crabby-images/316ed/316ed5b72e5d51f5a98e584fdc5ca03202fee7f8" alt="run-build.png 1887"
- To check that your build has started, click Agents, and then click Running.
data:image/s3,"s3://crabby-images/aec4f/aec4fb8e22e6ab307b65f2c2becea070bba94d3d" alt="running.png 1843"
- To check the build logs, open the Build Log tab.
You can see that the Repeater and scan have started, the polling state is also active. You can also monitor the scan progress in the Bright app.
data:image/s3,"s3://crabby-images/63378/633787bd4fafc60916f9c4a59b88f7fbcf9cca7d" alt="11.png 1885"
Updated over 1 year ago