Claude-skill-registry legacy-modernization

Modernize legacy applications and codebases. Use for COBOL conversion, framework upgrades, and technical debt reduction.

install
source · Clone the upstream repo
git clone https://github.com/majiayu000/claude-skill-registry
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/majiayu000/claude-skill-registry "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/data/legacy-modernization" ~/.claude/skills/majiayu000-claude-skill-registry-legacy-modernization && rm -rf "$T"
manifest: skills/data/legacy-modernization/SKILL.md
source content

🏗️ Legacy Modernization Skill

Modernization Patterns

Strangler Fig Pattern

1. Create new service alongside legacy
2. Route new features to modern service
3. Gradually migrate existing features
4. Eventually retire legacy system

Anti-Corruption Layer

// Legacy API returns old format
const legacyResponse = await legacyApi.getUser(id);
// { usr_id: 1, usr_nm: 'John', usr_email: 'john@example.com' }

// Transform to modern format
const modernUser = {
  id: legacyResponse.usr_id,
  name: legacyResponse.usr_nm,
  email: legacyResponse.usr_email
};

Common Modernization Tasks

JavaScript Upgrades

// ES5 → ES6+
// var → const/let
var name = 'John';  // ❌
const name = 'John'; // ✅

// function → arrow
function add(a, b) { return a + b; }  // Old
const add = (a, b) => a + b;          // Modern

// Callback → Promise → Async/Await
// Callback
getData(function(err, data) { ... });
// Promise
getData().then(data => ...).catch(err => ...);
// Async/Await
const data = await getData();

jQuery → Vanilla JS

// jQuery
$('.button').click(function() { ... });
$('#result').html(data);

// Vanilla JS
document.querySelector('.button').addEventListener('click', () => { ... });
document.getElementById('result').innerHTML = data;

Class → Functional (React)

// Class Component
class Counter extends Component {
  state = { count: 0 };
  componentDidMount() { ... }
  render() { return <div>{this.state.count}</div>; }
}

// Functional + Hooks
function Counter() {
  const [count, setCount] = useState(0);
  useEffect(() => { ... }, []);
  return <div>{count}</div>;
}

Database Modernization

FromToStrategy
SQL ServerPostgreSQLpg_chameleon
MySQLPostgreSQLpgloader
OraclePostgreSQLora2pg
MongoDB → SQLPrismaCustom scripts

Modernization Checklist

  • Document current architecture
  • Identify pain points
  • Create incremental plan
  • Set up parallel testing
  • Migrate with feature flags
  • Monitor and validate
  • Roll back if needed
  • Decommission legacy