Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Release] Stage to Main #3411

Merged
merged 10 commits into from
Jan 7, 2025
Merged
178 changes: 178 additions & 0 deletions .github/workflows/servicenow.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,178 @@
import requests
import time
import datetime
import timedelta
import json
import os
import sys

def find_string_in_json(json_data, target_string):
"""
Finds a target string in a JSON object.

Args:
json_data (dict or list): The JSON data to search.
target_string (str): The string to find.

Returns:
bool: True if the string is found, False otherwise.
"""

if isinstance(json_data, dict):
for key, value in json_data.items():
if isinstance(value, str) and target_string in value:
return True
elif isinstance(value, (dict, list)):
if find_string_in_json(value, target_string):
return True
elif isinstance(json_data, list):
for item in json_data:
if isinstance(item, str) and target_string in item:
return True
elif isinstance(item, (dict, list)):
if find_string_in_json(item, target_string):
return True

return False

# Execute Script logic:
# python3 servicenow.py
if __name__ == "__main__":

print("Starting CMR Action...")

print("Setting Planned Maintenance Time Windows for CMR...")
start_time = (datetime.datetime.now() + datetime.timedelta(seconds = 10)).timestamp()
end_time = (datetime.datetime.now() + datetime.timedelta(minutes = 10)).timestamp()

print("Set Release Summary for CMR...")
release_title = os.environ['PR_TITLE']
release_details = os.environ['PR_BODY']
pr_num = os.environ['PR_NUMBER']
pr_created = os.environ['PR_CREATED_AT']
pr_merged = os.environ['PR_MERGED_AT']
release_summary = f"Release_Details: {release_details} \n\nPull Request Number: {pr_num} \nPull Request Created At: {pr_created} \nPull Request Merged At: {pr_merged}"

print("Getting IMS Token")
ims_url = 'https://ims-na1.adobelogin.com/ims/token'
headers = {"Content-Type":"multipart/form-data"}
data = {
'client_id': os.environ['IMSACCESS_CLIENT_ID'],
'client_secret': os.environ['IMSACCESS_CLIENT_SECRET'],
'grant_type': "authorization_code",
'code': os.environ['IMSACCESS_AUTH_CODE']
}
response = requests.post(ims_url, data=data)
jsonParse = json.loads(response.text)

if response.status_code != 200:
print("POST failed with response code: ", response.status_code)
print(response.text)
sys.exit(1)
elif find_string_in_json(jsonParse, "error"):
print("IMS token request failed with response code: ", response.status_code)
print(response.text)
sys.exit(1)
else:
print("IMS token request was successful")
token = jsonParse["access_token"]

print("Create CMR in ServiceNow...")

servicenow_cmr_url = 'https://ipaasapi.adobe-services.com/change_management/changes'
headers = {
"Accept":"application/json",
"Authorization":token,
"Content-Type":"application/json",
"api_key":os.environ['IPAAS_KEY']
}
data = {
"title":release_title,
"description":release_summary,
"instanceIds": [ 537445 ],
"plannedStartDate": start_time,
"plannedEndDate": end_time,
"coordinator": "narcis@adobe.com",
"customerImpact": "No Impact",
"changeReason": [ "New Features", "Bug Fixes", "Enhancement", "Maintenance", "Security" ],
"preProductionTestingType": [ "End-to-End", "Functional", "Integrations", "QA", "Regression", "UAT", "Unit Test" ],
"backoutPlanType": "Roll back",
"approvedBy": [ "casalino@adobe.com", "jmichnow@adobe.com", "mauchley@adobe.com", "bbalakrishna@adobe.com", "tuscany@adobe.com", "brahmbha@adobe.com" ],
"testPlan": "Test plan is documented in the PR link in the Milo repository above. See the PR's merge checks to see Unit and Nala testing.",
"implementationPlan": "The change will be released as part of the continuous deployment of Milo's production branch, i.e., \"main\"",
"backoutPlan": "Revert merge to the Milo production branch by creating a revert commit.", "testResults": "Changes are tested and validated successfully in staging environment. Please see the link of the PR in the description for the test results and/or the \"#nala-test-results\" slack channel."
}
response = requests.post(servicenow_cmr_url, headers=headers, json=data)
jsonParse = json.loads(response.text)

if response.status_code != 200:
print("POST failed with response code: ", response.status_code)
print(response.text)
sys.exit(1)
elif find_string_in_json(jsonParse, "error"):
print("CMR creation failed with response code: ", response.status_code)
print(response.text)
sys.exit(1)
else:
print("CMR creation was successful")
transaction_id = jsonParse["id"]

print("Waiting for Transaction from Queue to ServiceNow then Retrieve CMR ID...")

servicenow_get_cmr_url = f'https://ipaasapi.adobe-services.com/change_management/transactions/{transaction_id}'
headers = {
"Accept":"application/json",
"Authorization":token,
"api_key":os.environ['IPAAS_KEY']
}

# Wait 10 seconds to provide time for the transaction to exit the queue and be saved into ServiceNow as a CMR record.
time.sleep(10)
response = requests.get(servicenow_get_cmr_url, headers=headers)
jsonParse = json.loads(response.text)

if response.status_code != 200:
print("GET failed with response code: ", response.status_code)
print(response.text)
sys.exit(1)
elif find_string_in_json(jsonParse, "error"):
print("CMR ID retrieval failed with response code: ", response.status_code)
print(response.text)
sys.exit(1)
else:
print("CMR ID retrieval was successful")
cmr_id = jsonParse["result"]["changeId"]

print("Setting Actual Maintenance Time Windows for CMR...")
actual_start_time = (datetime.datetime.now() - datetime.timedelta(seconds = 10)).timestamp()
actual_end_time = datetime.datetime.now().timestamp()

print("Closing CMR in ServiceNow...")

headers = {
"Accept":"application/json",
"Authorization":token,
"Content-Type":"application/json",
"api_key":os.environ['IPAAS_KEY']
}
data = {
"id": transaction_id,
"actualStartDate": actual_start_time,
"actualEndDate": actual_end_time,
"state": "Closed",
"closeCode": "Successful",
"notes": "The change request is closed as the change was released successfully"
}
response = requests.post(servicenow_cmr_url, headers=headers, json=data)
jsonParse = json.loads(response.text)

if response.status_code != 200:
print("POST failed with response code: ", response.status_code)
print(response.text)
sys.exit(1)
elif find_string_in_json(jsonParse, "error"):
print("CMR closure failed with response code: ", response.status_code)
print(response.text)
sys.exit(1)
else:
print("CMR closure was successful")
44 changes: 44 additions & 0 deletions .github/workflows/servicenow.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,44 @@
# This workflow will install Python dependencies, run CMR creation in ServiceNow
# For more information see: https://docs.github.com/en/actions/automating-builds-and-tests/building-and-testing-python

name: Create CMR in ServiceNow

on:
pull_request:
types:
- closed
branches:
- main

permissions:
contents: read

env:
IMSACCESS_CLIENT_ID: ${{ secrets.IMSACCESS_CLIENT_ID }}
IMSACCESS_CLIENT_SECRET: ${{ secrets.IMSACCESS_CLIENT_SECRET_PROD }}
IMSACCESS_AUTH_CODE: ${{ secrets.IMSACCESS_AUTH_CODE_PROD }}
IPAAS_KEY: ${{ secrets.IPAAS_KEY_PROD }}
PR_TITLE: ${{ github.event.pull_request.title }}
PR_BODY: ${{ github.event.pull_request.body }}
PR_NUMBER: ${{ github.event.pull_request.number }}
PR_CREATED_AT: ${{ github.event.pull_request.created_at }}
PR_MERGED_AT: ${{ github.event.pull_request.merged_at }}

jobs:
build:
# Only run this workflow on pull requests that have merged and not manually closed by user
if: github.event.pull_request.merged == true
runs-on: ubuntu-latest

steps:
- uses: actions/checkout@v4
- name: Set up Python 3.x, latest minor release
uses: actions/setup-python@v5
with:
python-version: "3.x"
- name: Install dependencies
run: |
python -m pip install --upgrade pip requests timedelta
- name: Execute script for creating and closing CMR
run: |
python ./.github/workflows/servicenow.py
130 changes: 0 additions & 130 deletions .github/workflows/skms.yaml

This file was deleted.

7 changes: 0 additions & 7 deletions libs/blocks/action-item/action-item.css
Original file line number Diff line number Diff line change
Expand Up @@ -114,18 +114,11 @@
transition: transform .2s ease;
}

.action-item:not(.zoom) a:focus-visible picture:not(.floated-icon) img,
.action-item.zoom a:focus-visible picture:not(.floated-icon) {
outline-color: -webkit-focus-ring-color;
outline-style: auto;
}

.action-item:not(.float-button) a {
width: 100%;
}

.action-item a:not(.con-button):focus-visible {
outline: none;
text-decoration: underline;
}

Expand Down
2 changes: 1 addition & 1 deletion libs/blocks/action-scroller/action-scroller.css
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@
grid-auto-columns: minmax(var(--action-scroller-column-width), 1fr);
grid-auto-flow: column;
gap: var(--spacing-m);
padding: 0 var(--action-scroller-mobile-padding);
padding: 3px var(--action-scroller-mobile-padding);
overflow-x: auto;
-ms-overflow-style: none;
scrollbar-width: none;
Expand Down
16 changes: 16 additions & 0 deletions libs/blocks/locui-create/locui-create.css
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
.locui-create.missing-details {
margin: 0 auto;
margin-top: 10vh;
max-width: 60%;
border-radius: 10px;
border: 10px solid var(--color-gray-200);
padding: 10px 30px 30px;
}

.locui-create .goto-step ul {
list-style-type: disc;
}

.locui-create .goto-step p {
margin: 0;
}
Loading
Loading