Hi, after upgrading from v7.0.2. to v8.0.0., I've been having issues running static export. After running next export, I get an error:
$ next export
> using build directory: /Users/fikip/Desktop/Projects/<project_name>/.next
  copying "static" directory
  copying "static build" directory
  launching 7 threads with concurrency of 10 per thread
TypeError: Cannot read property 'publicRuntimeConfig' of undefined
To be more specific, my publicRuntimeConfig in next.config.js is set up like this:
  publicRuntimeConfig: {
    API_URL: process.env.API_URL,
    SENTRY_URL: process.env.SENTRY_URL,
    SENTRY_SERVER_URL: process.env.SENTRY_SERVER_URL,
    VERSION: require("./package.json").version,
  }
Tracking down the error, it seems to occur here:
import getConfig from "next/config"
const { API_URL } = getConfig().publicRuntimeConfig
There have been no changes except updating next.js from v7.0.2 to v8.0.0.
I've noticed in the v8 release blog summary that
"publicRuntimeConfig and serverRuntimeConfig are not supported in the serverless mode. Use build-time configuration instead.", so that got me thinking that maybe setting target explicitly to server might help, but, alas, it did not.
publicRuntimeConfiggetConfig() somewhere in the app & access the publicRuntimeConfig object that should be returnedStatic export should finish without any errors.

I've found a solution that helped in another (albeit not completely related) thread: https://github.com/zeit/next.js/issues/4024#issuecomment-377837421
Replace 
const { API_URL } = getConfig().publicRuntimeConfig
with
const { publicRuntimeConfig = {} } = getConfig() || {}
const { API_URL } = publicRuntimeConfig
I'm not really clear on why this error started happening after the update. Is this the intended way I'm supposed to access publicRuntimeConfig in an app that is both statically served & dynamically served? Was it just 'luck' that it worked until now? 馃槃
I think this is a bug. Could you do me a favor and create a minimal github repository so that we can reproduce it faster when we start working on a fix 馃檹
Here is a repo with the issue.
https://github.com/zeit/next.js/tree/canary/examples/with-universal-configuration-runtime
Its also failing when I try to do an export using the one from the example, when I add an export step.
Fixed in 8.0.0-canary.24
Thanks a lot for the fix! Any idea of when a 8.0.1 might be released?
Adding in a few more bugfixes. Most likely will do a new release today 馃憤
Awesome, thanks! 馃檹
@bozskejkaja Your workaround would prevent errors, but I believe you will just have undefined values for all your environment variables if you export :thinking: 
@NathanielHill You're absolutely right, it's definitely not an actual solution to the issue. In my case, it was a sufficient workaround since I'm not really using the env variables after statically exporting the app.
Luckily, it looks like the issue is already resolved in 8.0.1 that just got released 馃帀
It's released as 8.0.1 馃憤
Thanks again! 馃憣
Not working for me in Next v9
I'm facing the same issue in Next v9 when trying to update my next.config.js webpack config:
require('dotenv').config();
const Dotenv = require('dotenv-webpack');
const path = require('path');
const UglifyJsPlugin = require('uglifyjs-webpack-plugin');
module.exports = (config, { dev /* , isServer */ }) => {
  const { resolve } = config;
  /* If you update `modules`, make sure you also update 
  .eslintrc.js > settings > 'import/resolver' > node > moduleDirectory  */
  const modules = [...resolve.modules, __dirname];
  const extensions = [...resolve.extensions, '.js', '.jsx', '.react.js'];
  const mainFields = [...resolve.mainFields, 'browser', 'jsnext:main', 'main'];
  const plugins = dev
    ? [
        ...config.plugins,
        new Dotenv({
          path: path.join(__dirname, '.env'),
          systemvars: true
        })
      ]
    : config.plugins;
  return {
    ...config,
    resolve: {
      ...resolve,
      modules,
      extensions,
      mainFields
    },
    plugins,
    optimization: {
      minimizer: [
        new UglifyJsPlugin({
          uglifyOptions: {
            output: {
              comments: /@preserve/i
            }
          },
          extractComments: false
        })
      ]
    }
  };
};
Any idea why?
using Next v9 and this still works:
const { publicRuntimeConfig = {} } = getConfig() || {};
const { APP_NODE_ENV } = publicRuntimeConfig;
I found that if you need it working for static pages, you need it set at build time,
like:
API_IS_TEST=1 npm run build
Hi, I can repro in v9.4:
https://github.com/VulcanJS/vulcan-next-starter/tree/bugfix/nextConfigStatic
git clone https://github.com/VulcanJS/vulcan-next-starter.git
git checkbout bugfix/nextConfigStatic
yarn run jest nextConfig # tests passes ok
DEBUG=next yarn run build:static # not OK
In the log you'll see the full config correctly computed. But in src/lib/i18n.ts, the getConfig() will return an object {serverRuntimeConfig: {}, publicRuntimeConfig: undefined}.
I keep exploring the issue, I have a complete setup with TS and Webpack so I am not sure where the problem happens.
Edit: I think I caught it, when the publicRuntimeConfig is an empty object, it gets scraped out and becomes undefined. If you just add yourConfig.publicRuntimeConfig = { foobar: true }, it is not scraped out and stays the same.
Quickfix is doing "publicRuntimeConfig || {}" when you get it but that's not intuitive. I can't find type definitions for getConfig either so we can't tell if this property is optional or not intuitively.
Most helpful comment
Adding in a few more bugfixes. Most likely will do a new release today 馃憤