HEX
Server: Apache/2.4.65 (Ubuntu)
System: Linux ielts-store-v2 6.8.0-1036-gcp #38~22.04.1-Ubuntu SMP Thu Aug 14 01:19:18 UTC 2025 x86_64
User: root (0)
PHP: 7.2.34-54+ubuntu20.04.1+deb.sury.org+1
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,
Upload Files
File: //snap/google-cloud-cli/current/lib/googlecloudsdk/command_lib/emulators/config.py
# -*- coding: utf-8 -*- #
# Copyright 2017 Google LLC. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#    http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""Code related to proxy and emulator configuration."""

from __future__ import absolute_import
from __future__ import division
from __future__ import unicode_literals

import json
from googlecloudsdk.command_lib.emulators import datastore_util
from googlecloudsdk.command_lib.emulators import pubsub_util
from googlecloudsdk.core.util import files
import six


# This is a list of all of the emulators currently supported, for use in
# the code pertaining to launching emulators. New emulators should be
# included here as they are added.
EMULATORS = {}
for emulator in [datastore_util.DatastoreEmulator(),
                 pubsub_util.PubsubEmulator()]:
  EMULATORS[emulator.service_name] = emulator


def WriteRoutesConfig(emulators, output_file):
  """This writes out the routes information to a file.

  The routes will be written as json in the format
  {service1: [route1, route2], service2: [route3, route4]}

  Args:
    emulators: [str], emulators to route the traffic of
    output_file: str, file to write the configuration to
  """
  routes = {name: emulator.prefixes
            for name, emulator in six.iteritems(emulators)}

  files.WriteFileContents(output_file, json.dumps(routes, indent=2))


# The configuration we get off the wire will be parsed and put into this object
# This object will then help us generate the ClusterInfo objects that are
# necessary, and other general route configuration
class ProxyConfiguration(object):
  """Configuration necessary to initialize the proxy."""

  def __init__(self, local_emulators, should_proxy_to_gcp, proxy_port):
    """Initializes object.

    Args:
      local_emulators: dict, the emulators and the ports they'll listen on
      should_proxy_to_gcp: bool, whether traffic to other emulators should
                           go to prod or not
      proxy_port: int, the port the proxy should bind to
    """
    self._local_emulators = local_emulators
    self._proxy_port = proxy_port
    self._should_proxy_to_gcp = should_proxy_to_gcp

  def WriteJsonToFile(self, output_file):
    """Writes configuration to file.

    The format will be
    {"localEmulators": {emulator1: port1, emulator2: port2},
     "proxyPort": port,
     "shouldProxyToGcp": bool}

    Args:
      output_file: str, file to write to
    """
    data = {
        'localEmulators': self._local_emulators,
        'proxyPort': self._proxy_port,
        'shouldProxyToGcp': self._should_proxy_to_gcp,
    }
    files.WriteFileContents(output_file, json.dumps(data, indent=2))