Move format_launch_changes to agenda.thespacedevs
This commit is contained in:
		
							parent
							
								
									bc4d956042
								
							
						
					
					
						commit
						fd7488bd04
					
				| 
						 | 
					@ -183,3 +183,68 @@ def get_launches(
 | 
				
			||||||
    filename = os.path.join(rocket_dir, f)
 | 
					    filename = os.path.join(rocket_dir, f)
 | 
				
			||||||
    data = json.load(open(filename))
 | 
					    data = json.load(open(filename))
 | 
				
			||||||
    return [summarize_launch(launch) for launch in data["results"]]
 | 
					    return [summarize_launch(launch) for launch in data["results"]]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					def format_launch_changes(differences: StrDict) -> str:
 | 
				
			||||||
 | 
					    """Convert deepdiff output to human-readable format."""
 | 
				
			||||||
 | 
					    changes = []
 | 
				
			||||||
 | 
					    # Handle value changes
 | 
				
			||||||
 | 
					    if "values_changed" in differences:
 | 
				
			||||||
 | 
					        for path, change in differences["values_changed"].items():
 | 
				
			||||||
 | 
					            field = path.replace("root['", "").replace("']", "").replace("root.", "")
 | 
				
			||||||
 | 
					            old_val = change["old_value"]
 | 
				
			||||||
 | 
					            new_val = change["new_value"]
 | 
				
			||||||
 | 
					            # Format specific fields nicely
 | 
				
			||||||
 | 
					            if field == "net":
 | 
				
			||||||
 | 
					                try:
 | 
				
			||||||
 | 
					                    old_dt = datetime.fromisoformat(old_val.replace("Z", "+00:00"))
 | 
				
			||||||
 | 
					                    new_dt = datetime.fromisoformat(new_val.replace("Z", "+00:00"))
 | 
				
			||||||
 | 
					                    changes.append(
 | 
				
			||||||
 | 
					                        "Launch time changed from "
 | 
				
			||||||
 | 
					                        + old_dt.strftime("%d %b %Y at %H:%M UTC")
 | 
				
			||||||
 | 
					                        + " to "
 | 
				
			||||||
 | 
					                        + new_dt.strftime("%d %b %Y at %H:%M UTC")
 | 
				
			||||||
 | 
					                    )
 | 
				
			||||||
 | 
					                except:
 | 
				
			||||||
 | 
					                    changes.append(f"Launch time changed from {old_val} to {new_val}")
 | 
				
			||||||
 | 
					            elif field == "name":
 | 
				
			||||||
 | 
					                changes.append(f"Mission name changed from '{old_val}' to '{new_val}'")
 | 
				
			||||||
 | 
					            elif field == "probability":
 | 
				
			||||||
 | 
					                if old_val is None:
 | 
				
			||||||
 | 
					                    changes.append(f"Launch probability set to {new_val}%")
 | 
				
			||||||
 | 
					                elif new_val is None:
 | 
				
			||||||
 | 
					                    changes.append("Launch probability removed")
 | 
				
			||||||
 | 
					                else:
 | 
				
			||||||
 | 
					                    changes.append(
 | 
				
			||||||
 | 
					                        f"Launch probability changed from {old_val}% to {new_val}%"
 | 
				
			||||||
 | 
					                    )
 | 
				
			||||||
 | 
					            elif "status" in field:
 | 
				
			||||||
 | 
					                changes.append(f"Status changed from '{old_val}' to '{new_val}'")
 | 
				
			||||||
 | 
					            else:
 | 
				
			||||||
 | 
					                changes.append(
 | 
				
			||||||
 | 
					                    f"{field.replace('_', ' ').title()} changed "
 | 
				
			||||||
 | 
					                    + f"from '{old_val}' to '{new_val}'"
 | 
				
			||||||
 | 
					                )
 | 
				
			||||||
 | 
					    # Handle additions
 | 
				
			||||||
 | 
					    if "dictionary_item_added" in differences:
 | 
				
			||||||
 | 
					        for path in differences["dictionary_item_added"]:
 | 
				
			||||||
 | 
					            field = path.replace("root['", "").replace("']", "").replace("root.", "")
 | 
				
			||||||
 | 
					            changes.append(f"New field added: {field.replace('_', ' ').title()}")
 | 
				
			||||||
 | 
					    # Handle removals
 | 
				
			||||||
 | 
					    if "dictionary_item_removed" in differences:
 | 
				
			||||||
 | 
					        for path in differences["dictionary_item_removed"]:
 | 
				
			||||||
 | 
					            field = path.replace("root['", "").replace("']", "").replace("root.", "")
 | 
				
			||||||
 | 
					            changes.append(f"Field removed: {field.replace('_', ' ').title()}")
 | 
				
			||||||
 | 
					    # Handle type changes
 | 
				
			||||||
 | 
					    if "type_changes" in differences:
 | 
				
			||||||
 | 
					        for path, change in differences["type_changes"].items():
 | 
				
			||||||
 | 
					            field = path.replace("root['", "").replace("']", "").replace("root.", "")
 | 
				
			||||||
 | 
					            changes.append(
 | 
				
			||||||
 | 
					                f"{field.replace('_', ' ').title()} type changed "
 | 
				
			||||||
 | 
					                + f"from {change['old_type'].__name__} to {change['new_type'].__name__}"
 | 
				
			||||||
 | 
					            )
 | 
				
			||||||
 | 
					    return (
 | 
				
			||||||
 | 
					        "\n".join(f"• {change}" for change in changes)
 | 
				
			||||||
 | 
					        if changes
 | 
				
			||||||
 | 
					        else "No specific changes detected"
 | 
				
			||||||
 | 
					    )
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
							
								
								
									
										67
									
								
								update.py
									
									
									
									
									
								
							
							
						
						
									
										67
									
								
								update.py
									
									
									
									
									
								
							| 
						 | 
					@ -109,71 +109,6 @@ Agenda: https://edwardbetts.com/agenda/
 | 
				
			||||||
    agenda.mail.send_mail(config, subject, body)
 | 
					    agenda.mail.send_mail(config, subject, body)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
def format_launch_changes(differences: StrDict) -> str:
 | 
					 | 
				
			||||||
    """Convert deepdiff output to human-readable format."""
 | 
					 | 
				
			||||||
    changes = []
 | 
					 | 
				
			||||||
    # Handle value changes
 | 
					 | 
				
			||||||
    if "values_changed" in differences:
 | 
					 | 
				
			||||||
        for path, change in differences["values_changed"].items():
 | 
					 | 
				
			||||||
            field = path.replace("root['", "").replace("']", "").replace("root.", "")
 | 
					 | 
				
			||||||
            old_val = change["old_value"]
 | 
					 | 
				
			||||||
            new_val = change["new_value"]
 | 
					 | 
				
			||||||
            # Format specific fields nicely
 | 
					 | 
				
			||||||
            if field == "net":
 | 
					 | 
				
			||||||
                try:
 | 
					 | 
				
			||||||
                    old_dt = datetime.fromisoformat(old_val.replace("Z", "+00:00"))
 | 
					 | 
				
			||||||
                    new_dt = datetime.fromisoformat(new_val.replace("Z", "+00:00"))
 | 
					 | 
				
			||||||
                    changes.append(
 | 
					 | 
				
			||||||
                        "Launch time changed from "
 | 
					 | 
				
			||||||
                        + old_dt.strftime("%d %b %Y at %H:%M UTC")
 | 
					 | 
				
			||||||
                        + " to "
 | 
					 | 
				
			||||||
                        + new_dt.strftime("%d %b %Y at %H:%M UTC")
 | 
					 | 
				
			||||||
                    )
 | 
					 | 
				
			||||||
                except:
 | 
					 | 
				
			||||||
                    changes.append(f"Launch time changed from {old_val} to {new_val}")
 | 
					 | 
				
			||||||
            elif field == "name":
 | 
					 | 
				
			||||||
                changes.append(f"Mission name changed from '{old_val}' to '{new_val}'")
 | 
					 | 
				
			||||||
            elif field == "probability":
 | 
					 | 
				
			||||||
                if old_val is None:
 | 
					 | 
				
			||||||
                    changes.append(f"Launch probability set to {new_val}%")
 | 
					 | 
				
			||||||
                elif new_val is None:
 | 
					 | 
				
			||||||
                    changes.append("Launch probability removed")
 | 
					 | 
				
			||||||
                else:
 | 
					 | 
				
			||||||
                    changes.append(
 | 
					 | 
				
			||||||
                        f"Launch probability changed from {old_val}% to {new_val}%"
 | 
					 | 
				
			||||||
                    )
 | 
					 | 
				
			||||||
            elif "status" in field:
 | 
					 | 
				
			||||||
                changes.append(f"Status changed from '{old_val}' to '{new_val}'")
 | 
					 | 
				
			||||||
            else:
 | 
					 | 
				
			||||||
                changes.append(
 | 
					 | 
				
			||||||
                    f"{field.replace('_', ' ').title()} changed "
 | 
					 | 
				
			||||||
                    + f"from '{old_val}' to '{new_val}'"
 | 
					 | 
				
			||||||
                )
 | 
					 | 
				
			||||||
    # Handle additions
 | 
					 | 
				
			||||||
    if "dictionary_item_added" in differences:
 | 
					 | 
				
			||||||
        for path in differences["dictionary_item_added"]:
 | 
					 | 
				
			||||||
            field = path.replace("root['", "").replace("']", "").replace("root.", "")
 | 
					 | 
				
			||||||
            changes.append(f"New field added: {field.replace('_', ' ').title()}")
 | 
					 | 
				
			||||||
    # Handle removals
 | 
					 | 
				
			||||||
    if "dictionary_item_removed" in differences:
 | 
					 | 
				
			||||||
        for path in differences["dictionary_item_removed"]:
 | 
					 | 
				
			||||||
            field = path.replace("root['", "").replace("']", "").replace("root.", "")
 | 
					 | 
				
			||||||
            changes.append(f"Field removed: {field.replace('_', ' ').title()}")
 | 
					 | 
				
			||||||
    # Handle type changes
 | 
					 | 
				
			||||||
    if "type_changes" in differences:
 | 
					 | 
				
			||||||
        for path, change in differences["type_changes"].items():
 | 
					 | 
				
			||||||
            field = path.replace("root['", "").replace("']", "").replace("root.", "")
 | 
					 | 
				
			||||||
            changes.append(
 | 
					 | 
				
			||||||
                f"{field.replace('_', ' ').title()} type changed "
 | 
					 | 
				
			||||||
                + f"from {change['old_type'].__name__} to {change['new_type'].__name__}"
 | 
					 | 
				
			||||||
            )
 | 
					 | 
				
			||||||
    return (
 | 
					 | 
				
			||||||
        "\n".join(f"• {change}" for change in changes)
 | 
					 | 
				
			||||||
        if changes
 | 
					 | 
				
			||||||
        else "No specific changes detected"
 | 
					 | 
				
			||||||
    )
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
def report_space_launch_change(
 | 
					def report_space_launch_change(
 | 
				
			||||||
    config: flask.config.Config, prev_launch: StrDict | None, cur_launch: StrDict | None
 | 
					    config: flask.config.Config, prev_launch: StrDict | None, cur_launch: StrDict | None
 | 
				
			||||||
) -> None:
 | 
					) -> None:
 | 
				
			||||||
| 
						 | 
					@ -277,7 +212,7 @@ View all launches: https://edwardbetts.com/agenda/launches
 | 
				
			||||||
        subject = f"Space Launch Update: {name}"
 | 
					        subject = f"Space Launch Update: {name}"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    differences = deepdiff.DeepDiff(prev_launch, cur_launch)
 | 
					    differences = deepdiff.DeepDiff(prev_launch, cur_launch)
 | 
				
			||||||
    changes_text = format_launch_changes(differences)
 | 
					    changes_text = agenda.thespacedevs.format_launch_changes(differences)
 | 
				
			||||||
    # Format launch date nicely
 | 
					    # Format launch date nicely
 | 
				
			||||||
    formatted_date = "Unknown"
 | 
					    formatted_date = "Unknown"
 | 
				
			||||||
    if launch_date and launch_date != "Unknown":
 | 
					    if launch_date and launch_date != "Unknown":
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
		Reference in a new issue