2014-08-31 16:06:39 +01:00
# -*- coding: utf-8 -*-
2014-09-03 17:29:13 +01:00
# Copyright 2014 OpenMarket Ltd
2014-08-31 16:06:39 +01:00
#
# 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.
import argparse
import sys
import os
2014-09-01 20:44:43 +01:00
import yaml
2014-08-31 16:06:39 +01:00
2014-09-02 10:48:05 +01:00
class ConfigError ( Exception ) :
pass
2014-08-31 16:06:39 +01:00
class Config ( object ) :
def __init__ ( self , args ) :
pass
2014-09-01 15:51:15 +01:00
@staticmethod
def abspath ( file_path ) :
return os . path . abspath ( file_path ) if file_path else file_path
2014-09-02 10:48:05 +01:00
@classmethod
def check_file ( cls , file_path , config_name ) :
if file_path is None :
raise ConfigError (
" Missing config for %s . "
" Try running again with --generate-config "
% ( config_name , )
)
if not os . path . exists ( file_path ) :
raise ConfigError (
" File % c onfig for %s doesn ' t exist. "
" Try running again with --generate-config "
% ( config_name , )
)
return cls . abspath ( file_path )
@classmethod
def read_file ( cls , file_path , config_name ) :
cls . check_file ( file_path , config_name )
2014-08-31 16:06:39 +01:00
with open ( file_path ) as file_stream :
return file_stream . read ( )
@staticmethod
def read_config_file ( file_path ) :
2014-09-01 20:44:43 +01:00
with open ( file_path ) as file_stream :
return yaml . load ( file_stream )
2014-08-31 16:06:39 +01:00
@classmethod
def add_arguments ( cls , parser ) :
pass
@classmethod
def generate_config ( cls , args , config_dir_path ) :
pass
@classmethod
def load_config ( cls , description , argv , generate_section = None ) :
config_parser = argparse . ArgumentParser ( add_help = False )
config_parser . add_argument (
" -c " , " --config-path " ,
metavar = " CONFIG_FILE " ,
help = " Specify config file "
)
2014-09-01 15:51:15 +01:00
config_parser . add_argument (
" --generate-config " ,
action = " store_true " ,
help = " Generate config file "
)
2014-08-31 16:06:39 +01:00
config_args , remaining_args = config_parser . parse_known_args ( argv )
2014-09-01 15:51:15 +01:00
if config_args . generate_config :
2014-08-31 16:06:39 +01:00
if not config_args . config_path :
config_parser . error (
" Must specify where to generate the config file "
)
config_dir_path = os . path . dirname ( config_args . config_path )
if os . path . exists ( config_args . config_path ) :
defaults = cls . read_config_file ( config_args . config_path )
2014-09-01 15:51:15 +01:00
else :
defaults = { }
2014-08-31 16:06:39 +01:00
else :
if config_args . config_path :
defaults = cls . read_config_file ( config_args . config_path )
else :
defaults = { }
parser = argparse . ArgumentParser (
parents = [ config_parser ] ,
description = description ,
formatter_class = argparse . RawDescriptionHelpFormatter ,
)
2014-09-01 15:51:15 +01:00
cls . add_arguments ( parser )
2014-08-31 16:06:39 +01:00
parser . set_defaults ( * * defaults )
args = parser . parse_args ( remaining_args )
2014-09-01 15:51:15 +01:00
if config_args . generate_config :
2014-08-31 16:06:39 +01:00
config_dir_path = os . path . dirname ( config_args . config_path )
config_dir_path = os . path . abspath ( config_dir_path )
2014-09-02 10:57:42 +01:00
if not os . path . exists ( config_dir_path ) :
os . makedirs ( config_dir_path )
2014-08-31 16:06:39 +01:00
cls . generate_config ( args , config_dir_path )
2014-09-01 20:44:43 +01:00
config = { }
2014-08-31 16:06:39 +01:00
for key , value in vars ( args ) . items ( ) :
2014-09-01 15:51:15 +01:00
if ( key not in set ( [ " config_path " , " generate_config " ] )
and value is not None ) :
2014-09-01 20:44:43 +01:00
config [ key ] = value
2014-08-31 16:06:39 +01:00
with open ( config_args . config_path , " w " ) as config_file :
2014-09-03 19:29:36 +01:00
# TODO(paul) it would be lovely if we wrote out vim- and emacs-
# style mode markers into the file, to hint to people that
# this is a YAML file.
2014-09-01 20:44:43 +01:00
yaml . dump ( config , config_file , default_flow_style = False )
2014-10-02 10:43:22 +01:00
print " A config file has been generated in %s (your server name is ' %s ' ). Please review this file and customise it to your needs. " % ( config_args . config_path , config [ ' server_name ' ] )
2014-09-01 15:51:15 +01:00
sys . exit ( 0 )
2014-08-31 16:06:39 +01:00
return cls ( args )