
Security News
Security Community Slams MIT-linked Report Claiming AI Powers 80% of Ransomware
Experts push back on new claims about AI-driven ransomware, warning that hype and sponsored research are distorting how the threat is understood.
@analogjs/vite-plugin-nitro
Advanced tools
A lightweight Vite plugin for integrating with Nitro to enable:
npm install @analogjs/vite-plugin-nitro --save-dev
Add the nitro plugin to the plugins array in the Vite config.
// vite.config.ts
import { defineConfig } from 'vite';
import react from '@vitejs/plugin-react';
import nitro from '@analogjs/vite-plugin-nitro';
// https://vitejs.dev/config/
export default defineConfig({
  plugins: [
    react(),
    nitro({
      ssr: true,
      entryServer: 'src/main.server.tsx',
      prerender: {
        routes: ['/'],
      },
    }),
  ],
});
Define a src/main.server.ts(x) file to declare how to render the application on the server.
Below is a minimal example for SSR w/React:
import React from 'react';
import ReactDOMServer from 'react-dom/server';
import App from './App';
export default async function render(_url: string, document: string) {
  const html = ReactDOMServer.renderToString(
    <React.StrictMode>
      <App />
    </React.StrictMode>,
  );
  return document.replace('<!--app-html-->', html);
}
Also setup the placeholder to be replaced in the index.html:
<!DOCTYPE html>
<html lang="en">
  <head>
    <title>Vite + React + Nitro</title>
  </head>
  <body>
    <div id="root"><!--app-html--></div>
    <script type="module" src="/src/main.tsx"></script>
  </body>
</html>
API routes are defined in the src/server/routes/api folder. API routes are also filesystem based,
and are exposed under the default /api prefix.
// src/server/routes/api/v1/hello
import { defineEventHandler } from 'h3';
export default defineEventHandler(() => ({ message: 'Hello World' }));
The API route can be accessed as /api/v1/hello.
By default, the src folder is used as the path for the discovery of server files and API routes. You can customize the folder with the sourceRoot option.
// vite.config.ts
import { defineConfig } from 'vite';
import nitro from '@analogjs/vite-plugin-nitro';
// https://vitejs.dev/config/
export default defineConfig({
  plugins: [
    nitro({
      ssr: true,
      entryServer: 'app/main.server.tsx',
      sourceRoot: 'app',
    }),
  ],
});
With this configuration, API routes are discovered under the app/server/routes/api directory. You can also make the it optional by setting the sourceRoot to '.';
React: https://github.com/brandonroberts/vite-nitro-react 
SolidJS: https://github.com/brandonroberts/vite-nitro-solid 
Vue: https://github.com/brandonroberts/vite-nitro-vue
FAQs
A Vite plugin for adding a nitro API server
The npm package @analogjs/vite-plugin-nitro receives a total of 16,838 weekly downloads. As such, @analogjs/vite-plugin-nitro popularity was classified as popular.
We found that @analogjs/vite-plugin-nitro demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Security News
Experts push back on new claims about AI-driven ransomware, warning that hype and sponsored research are distorting how the threat is understood.

Security News
Ruby's creator Matz assumes control of RubyGems and Bundler repositories while former maintainers agree to step back and transfer all rights to end the dispute.

Research
/Security News
Socket researchers found 10 typosquatted npm packages that auto-run on install, show fake CAPTCHAs, fingerprint by IP, and deploy a credential stealer.