diff --git a/food-open/.project b/food-open/.project
new file mode 100644
index 0000000..8f00824
--- /dev/null
+++ b/food-open/.project
@@ -0,0 +1,17 @@
+
+
+ food-open
+
+
+
+
+
+ org.eclipse.m2e.core.maven2Builder
+
+
+
+
+
+ org.eclipse.m2e.core.maven2Nature
+
+
diff --git a/food-open/.settings/org.eclipse.core.resources.prefs b/food-open/.settings/org.eclipse.core.resources.prefs
new file mode 100644
index 0000000..99f26c0
--- /dev/null
+++ b/food-open/.settings/org.eclipse.core.resources.prefs
@@ -0,0 +1,2 @@
+eclipse.preferences.version=1
+encoding/=UTF-8
diff --git a/food-open/.settings/org.eclipse.m2e.core.prefs b/food-open/.settings/org.eclipse.m2e.core.prefs
new file mode 100644
index 0000000..f897a7f
--- /dev/null
+++ b/food-open/.settings/org.eclipse.m2e.core.prefs
@@ -0,0 +1,4 @@
+activeProfiles=
+eclipse.preferences.version=1
+resolveWorkspaceProjects=true
+version=1
diff --git a/food-open/food-open-api/.classpath b/food-open/food-open-api/.classpath
new file mode 100644
index 0000000..772acef
--- /dev/null
+++ b/food-open/food-open-api/.classpath
@@ -0,0 +1,37 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/food-open/food-open-api/.project b/food-open/food-open-api/.project
new file mode 100644
index 0000000..c353976
--- /dev/null
+++ b/food-open/food-open-api/.project
@@ -0,0 +1,23 @@
+
+
+ food-open-api
+
+
+
+
+
+ org.eclipse.jdt.core.javabuilder
+
+
+
+
+ org.eclipse.m2e.core.maven2Builder
+
+
+
+
+
+ org.eclipse.jdt.core.javanature
+ org.eclipse.m2e.core.maven2Nature
+
+
diff --git a/food-open/food-open-api/.settings/org.eclipse.core.resources.prefs b/food-open/food-open-api/.settings/org.eclipse.core.resources.prefs
new file mode 100644
index 0000000..aedbd31
--- /dev/null
+++ b/food-open/food-open-api/.settings/org.eclipse.core.resources.prefs
@@ -0,0 +1,6 @@
+eclipse.preferences.version=1
+encoding//src/main/java=UTF-8
+encoding//src/main/resources=UTF-8
+encoding//src/test/java=UTF-8
+encoding/=UTF-8
+encoding/lib=UTF-8
diff --git a/food-open/food-open-api/.settings/org.eclipse.jdt.core.prefs b/food-open/food-open-api/.settings/org.eclipse.jdt.core.prefs
new file mode 100644
index 0000000..2f5cc74
--- /dev/null
+++ b/food-open/food-open-api/.settings/org.eclipse.jdt.core.prefs
@@ -0,0 +1,8 @@
+eclipse.preferences.version=1
+org.eclipse.jdt.core.compiler.codegen.targetPlatform=1.8
+org.eclipse.jdt.core.compiler.compliance=1.8
+org.eclipse.jdt.core.compiler.problem.enablePreviewFeatures=disabled
+org.eclipse.jdt.core.compiler.problem.forbiddenReference=warning
+org.eclipse.jdt.core.compiler.problem.reportPreviewFeatures=ignore
+org.eclipse.jdt.core.compiler.release=disabled
+org.eclipse.jdt.core.compiler.source=1.8
diff --git a/food-open/food-open-api/.settings/org.eclipse.m2e.core.prefs b/food-open/food-open-api/.settings/org.eclipse.m2e.core.prefs
new file mode 100644
index 0000000..f897a7f
--- /dev/null
+++ b/food-open/food-open-api/.settings/org.eclipse.m2e.core.prefs
@@ -0,0 +1,4 @@
+activeProfiles=
+eclipse.preferences.version=1
+resolveWorkspaceProjects=true
+version=1
diff --git a/food-open/food-open-api/assembly.xml b/food-open/food-open-api/assembly.xml
new file mode 100644
index 0000000..a23177b
--- /dev/null
+++ b/food-open/food-open-api/assembly.xml
@@ -0,0 +1,50 @@
+
+
+ package
+
+ dir
+ zip
+
+ true
+
+
+ src/main/bin
+ bin
+
+
+ src/main/resources
+ conf
+
+ application.properties
+ erp.properties
+ logback.xml
+
+
+
+ src/main/conf
+ conf
+
+
+ src/main/logs
+ logs
+
+
+ src/main/lib
+ lib
+
+
+ src/main/temp
+ temp
+
+
+
+
+
+ lib
+ ${artifactId}-${version}.jar
+
+
+
\ No newline at end of file
diff --git a/food-open/food-open-api/food-open-api.iml b/food-open/food-open-api/food-open-api.iml
new file mode 100644
index 0000000..0688d6c
--- /dev/null
+++ b/food-open/food-open-api/food-open-api.iml
@@ -0,0 +1,168 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/food-open/food-open-api/lib/open-core-1.0.0.jar b/food-open/food-open-api/lib/open-core-1.0.0.jar
new file mode 100644
index 0000000..8625869
Binary files /dev/null and b/food-open/food-open-api/lib/open-core-1.0.0.jar differ
diff --git a/food-open/food-open-api/lib/qiniu-logging-plugin-logback-1.0.1.jar b/food-open/food-open-api/lib/qiniu-logging-plugin-logback-1.0.1.jar
new file mode 100644
index 0000000..2c7da6d
Binary files /dev/null and b/food-open/food-open-api/lib/qiniu-logging-plugin-logback-1.0.1.jar differ
diff --git a/food-open/food-open-api/lib/qiniu-pandora-sdk-2.1.0.jar b/food-open/food-open-api/lib/qiniu-pandora-sdk-2.1.0.jar
new file mode 100644
index 0000000..ef61313
Binary files /dev/null and b/food-open/food-open-api/lib/qiniu-pandora-sdk-2.1.0.jar differ
diff --git a/food-open/food-open-api/pom.xml b/food-open/food-open-api/pom.xml
new file mode 100644
index 0000000..e06fa09
--- /dev/null
+++ b/food-open/food-open-api/pom.xml
@@ -0,0 +1,296 @@
+
+
+ 4.0.0
+
+ com.jwsaas
+ food-open
+ 2.0.0
+
+ food-open-api
+
+ food-open-api
+ http://maven.apache.org
+
+
+ UTF-8
+ 1.5.19.RELEASE
+ 2.5.0
+
+ 1.2.0
+ 1.4.9
+ 1.59
+ 3.1.0
+
+
+
+
+
+
+ org.springframework.boot
+ spring-boot-dependencies
+ ${spring.boot.version}
+ pom
+ import
+
+
+ org.springframework.data
+ spring-data-releasetrain
+ Fowler-SR2
+ import
+ pom
+
+
+
+
+
+
+ com.jwsaas
+ food-api
+
+
+ com.jwsaas
+ common-utils
+
+
+ commons-logging
+ commons-logging
+
+
+
+
+ com.jwsaas
+ common-dubbo
+
+
+ commons-logging
+ commons-logging
+
+
+ dubbo
+ com.alibaba
+
+
+ netty
+ io.netty
+
+
+
+
+ com.alibaba
+ dubbo
+ 2.6.5
+
+
+ netty
+ org.jboss.netty
+
+
+
+
+ com.jwsaas.open
+ open-core
+ 1.0.0
+ system
+ ${basedir}/lib/open-core-1.0.0.jar
+
+
+ org.springframework.boot
+ spring-boot-starter-web
+
+
+
+ org.springframework.boot
+ spring-boot-starter-freemarker
+
+
+ org.springframework.boot
+ spring-boot-starter-test
+ test
+
+
+
+ com.alibaba
+ fastjson
+
+
+
+ org.redisson
+ redisson
+
+
+
+ io.projectreactor.spring
+ reactor-spring-context
+
+
+ org.apache.commons
+ commons-lang3
+
+
+ commons-io
+ commons-io
+
+
+ org.apache.httpcomponents
+ httpclient
+
+
+ org.apache.httpcomponents
+ httpmime
+
+
+ net.sourceforge.pinyin4j
+ pinyin4j
+ ${pinyin4j.version}
+
+
+
+ org.springframework.boot
+ spring-boot-starter-amqp
+
+
+
+ org.eclipse.paho
+ org.eclipse.paho.client.mqttv3
+ ${mqttv3.version}
+
+
+ com.thoughtworks.xstream
+ xstream
+ ${xstream.version}
+
+
+
+ com.fasterxml.jackson.core
+ jackson-core
+
+
+ com.fasterxml.jackson.core
+ jackson-databind
+
+
+ com.fasterxml.jackson.dataformat
+ jackson-dataformat-xml
+
+
+ com.fasterxml.jackson.dataformat
+ jackson-dataformat-yaml
+
+
+ com.fasterxml.jackson.core
+ jackson-annotations
+
+
+ org.bouncycastle
+ bcprov-jdk15on
+ ${bcprov.jdk15o.version}
+
+
+ dom4j
+ dom4j
+ 1.6.1
+
+
+
+ javax.servlet
+ javax.servlet-api
+ ${servlet.api.version}
+ provided
+
+
+ com.qiniu
+ qiniu-logging-plugin-logback
+ 1.0.1
+ system
+ ${basedir}/lib/qiniu-logging-plugin-logback-1.0.1.jar
+
+
+ com.qiniu
+ qiniu-pandora-sdk
+ 2.1.0
+ system
+ ${basedir}/lib/qiniu-pandora-sdk-2.1.0.jar
+
+
+ com.squareup.okhttp3
+ okhttp
+ 3.3.1
+
+
+
+ com.google.code.gson
+ gson
+ 2.6.2
+
+
+
+
+
+
+
+ org.springframework.boot
+ spring-boot-maven-plugin
+ 2.5.6
+
+
+
+ repackage
+
+
+
+
+
+ maven-assembly-plugin
+
+ false
+
+ assembly.xml
+
+
+
+
+ make-assembly
+ package
+
+ single
+
+
+
+
+
+ org.apache.maven.plugins
+ maven-jar-plugin
+
+
+ application.properties
+ logback.xml
+
+
+
+
+
+
+
+
+ ${basedir}/lib
+ BOOT-INF/lib/
+
+ **/*.jar
+
+
+
+ src/main/resources
+ BOOT-INF/classes/
+
+ application.properties
+ logback.xml
+
+
+
+
+
+
+
+
diff --git a/food-open/food-open-api/readme/history.txt b/food-open/food-open-api/readme/history.txt
new file mode 100644
index 0000000..28d33c5
--- /dev/null
+++ b/food-open/food-open-api/readme/history.txt
@@ -0,0 +1,10 @@
+2018-04-16
+************更新记录************
+优化修复:
+1)xxx;
+
+
+新增功能:
+1)交班信息上传时增加支付方式明细信息;
+2)xxx;
+
diff --git a/food-open/food-open-api/readme/运行方式.txt b/food-open/food-open-api/readme/运行方式.txt
new file mode 100644
index 0000000..6ad5475
--- /dev/null
+++ b/food-open/food-open-api/readme/运行方式.txt
@@ -0,0 +1,21 @@
+1.com.boduo.Application中的main方法直接运行。适用于开发模式
+2.打包运行。适用于安装部署。
+注:
+
+
+
+ ${basedir}/src/lib
+ BOOT-INF/lib/
+
+ **/*.jar
+
+
+
+
+ src/main/resources
+ BOOT-INF/classes/
+
+
+
+
+
\ No newline at end of file
diff --git a/food-open/food-open-api/src/main/bin/install.bat b/food-open/food-open-api/src/main/bin/install.bat
new file mode 100644
index 0000000..046a68c
--- /dev/null
+++ b/food-open/food-open-api/src/main/bin/install.bat
@@ -0,0 +1,140 @@
+@echo off
+setlocal
+
+rem
+rem Copyright (c) 1999, 2016 Tanuki Software, Ltd.
+rem http://www.tanukisoftware.com
+rem All rights reserved.
+rem
+rem This software is the proprietary information of Tanuki Software.
+rem You shall use it only in accordance with the terms of the
+rem license agreement you entered into with Tanuki Software.
+rem http://wrapper.tanukisoftware.com/doc/english/licenseOverview.html
+rem
+rem Java Service Wrapper general passthrough startup script.
+rem
+
+rem -----------------------------------------------------------------------------
+rem These settings can be modified to fit the needs of your application
+rem Optimized for use with version 3.5.28 of the Wrapper.
+
+rem The base name for the Wrapper binary.
+set _WRAPPER_BASE=wrapper
+
+rem The directory where the Wrapper binary (.exe) file is located. It can be
+rem either an absolute or a relative path. If the path contains any special
+rem characters, please make sure to quote the variable.
+set _WRAPPER_DIR=
+
+rem The name and location of the Wrapper configuration file. This will be used
+rem if the user does not specify a configuration file as the first parameter to
+rem this script.
+set _WRAPPER_CONF_DEFAULT="../conf/%_WRAPPER_BASE%.conf"
+
+rem Makes it possible to override the Wrapper configuration file by specifying it
+rem as the first parameter.
+rem set _WRAPPER_CONF_OVERRIDE=true
+
+rem _PASS_THROUGH tells the script to pass all parameters through to the JVM
+rem as is.
+rem If _WRAPPER_CONF_OVERRIDE is specified then all parameters will be passed.
+rem If not set then all parameters starting with the second will be passed.
+set _PASS_THROUGH=true
+
+rem Do not modify anything beyond this point
+rem -----------------------------------------------------------------------------
+
+rem
+rem Resolve the real path of the wrapper.exe
+rem For non NT systems, the _REALPATH and _WRAPPER_CONF values
+rem can be hard-coded below and the following test removed.
+rem
+if "%OS%"=="Windows_NT" goto nt
+echo This script only works with NT-based versions of Windows.
+goto :eof
+
+:nt
+rem Find the application home.
+rem if no path path specified do the default action
+IF not DEFINED _WRAPPER_DIR goto dir_undefined
+set _WRAPPER_DIR_QUOTED="%_WRAPPER_DIR:"=%"
+if not "%_WRAPPER_DIR:~-2,1%" == "\" set _WRAPPER_DIR_QUOTED="%_WRAPPER_DIR_QUOTED:"=%\"
+rem check if absolute path
+if "%_WRAPPER_DIR_QUOTED:~2,1%" == ":" goto absolute_path
+if "%_WRAPPER_DIR_QUOTED:~1,1%" == "\" goto absolute_path
+rem everythig else means relative path
+set _REALPATH="%~dp0%_WRAPPER_DIR_QUOTED:"=%"
+goto pathfound
+
+:dir_undefined
+rem Use a relative path to the wrapper %~dp0 is location of current script under NT
+set _REALPATH="%~dp0"
+goto pathfound
+:absolute_path
+rem Use an absolute path to the wrapper
+set _REALPATH="%_WRAPPER_DIR_QUOTED:"=%"
+
+:pathfound
+rem
+rem Decide on the specific Wrapper binary to use (See delta-pack)
+rem
+if "%PROCESSOR_ARCHITEW6432%"=="AMD64" goto amd64
+if "%PROCESSOR_ARCHITECTURE%"=="AMD64" goto amd64
+if "%PROCESSOR_ARCHITECTURE%"=="IA64" goto ia64
+set _WRAPPER_L_EXE="%_REALPATH:"=%%_WRAPPER_BASE%-windows-x86-32.exe"
+goto search
+:amd64
+set _WRAPPER_L_EXE="%_REALPATH:"=%%_WRAPPER_BASE%-windows-x86-64.exe"
+goto search
+:ia64
+set _WRAPPER_L_EXE="%_REALPATH:"=%%_WRAPPER_BASE%-windows-ia-64.exe"
+goto search
+:search
+set _WRAPPER_EXE="%_WRAPPER_L_EXE:"=%"
+if exist %_WRAPPER_EXE% goto conf
+set _WRAPPER_EXE="%_REALPATH:"=%%_WRAPPER_BASE%.exe"
+if exist %_WRAPPER_EXE% goto conf
+echo Unable to locate a Wrapper executable using any of the following names:
+echo %_WRAPPER_L_EXE%
+echo %_WRAPPER_EXE%
+pause
+goto :eof
+
+rem
+rem Find the wrapper.conf
+rem
+:conf
+if [%_WRAPPER_CONF_OVERRIDE%]==[true] (
+ set _WRAPPER_CONF="%~f1"
+ if not [%_WRAPPER_CONF%]==[""] (
+ shift
+ goto :startup
+ )
+)
+set _WRAPPER_CONF="%_WRAPPER_CONF_DEFAULT:"=%"
+
+rem
+rem Start the Wrapper
+rem
+:startup
+if not [%_PASS_THROUGH%]==[true] (
+ if not [%1]==[] (
+ echo WARNING: Extra arguments will be ignored. Please check usage in the batch file.
+ )
+)
+
+rem Collect the application parameters
+:parameters
+set _PARAMETERS=%_PARAMETERS% %1
+shift
+if not [%1]==[] goto :parameters
+
+if not [%_PASS_THROUGH%]==[true] (
+ %_WRAPPER_EXE% -i %_WRAPPER_CONF%
+) else (
+ %_WRAPPER_EXE% -i %_WRAPPER_CONF% -- %_PARAMETERS%
+)
+if not errorlevel 1 goto :eof
+pause
+
+
diff --git a/food-open/food-open-api/src/main/bin/middleware b/food-open/food-open-api/src/main/bin/middleware
new file mode 100644
index 0000000..3f3ad3f
--- /dev/null
+++ b/food-open/food-open-api/src/main/bin/middleware
@@ -0,0 +1,2162 @@
+#! /bin/sh
+
+#
+# Copyright (c) 1999, 2016 Tanuki Software, Ltd.
+# http://www.tanukisoftware.com
+# All rights reserved.
+#
+# This software is the proprietary information of Tanuki Software.
+# You shall use it only in accordance with the terms of the
+# license agreement you entered into with Tanuki Software.
+# http://wrapper.tanukisoftware.com/doc/english/licenseOverview.html
+#
+# Java Service Wrapper sh script. Suitable for starting and stopping
+# wrapped Java applications on UNIX platforms.
+#
+
+#-----------------------------------------------------------------------------
+# These settings can be modified to fit the needs of your application
+# Optimized for use with version 3.5.28 of the Wrapper.
+
+#********************************************************************
+# NOTE - This script has been modified to run the TestWrapper sample
+# application and should NOT be used as a base for your own
+# applications. All of the documentation assumes that you are
+# working from the default source script:
+# WRAPPER_HOME/src/bin/sh.script.in
+#********************************************************************
+
+# IMPORTANT - Please always stop and uninstall an application before making
+# any changes to this file. Failure to do so could remove the
+# script's ability to control the application.
+
+# Initialization block for the install_initd and remove_initd scripts used by
+# SUSE linux, CentOS and RHEL distributions.
+# Note: From CentOS 6, make sure the BEGIN INIT INFO section is before any line
+# of code otherwise the service won't be displayed in the Service
+# Configuration GUI.
+### BEGIN INIT INFO
+# Provides: wrapper
+# Required-Start: $local_fs $network $syslog
+# Should-Start:
+# Required-Stop:
+# Default-Start: 2 3 4 5
+# Default-Stop: 0 1 6
+# Short-Description: Wrapper Sample Application
+# Description: Wrapper Sample Application Description
+### END INIT INFO
+
+# Application
+APP_NAME="Food-2.0 Open Api"
+APP_LONG_NAME="Food-2.0 Open Api Application"
+
+# If uncommented (and set to false), APP_NAME and APP_LONG_NAME will no longer
+# be passed to the wrapper. See documentation for details.
+#APP_NAME_PASS_TO_WRAPPER=false
+
+# Wrapper
+WRAPPER_CMD="./wrapper"
+WRAPPER_CONF="../conf/wrapper.conf"
+
+# Priority at which to run the wrapper. See "man nice" for valid priorities.
+# nice is only used if a priority is specified.
+PRIORITY=
+
+# Location of the pid file.
+PIDDIR="."
+
+# PIDFILE_CHECK_PID tells the script to double check whether the pid in the pid
+# file actually exists and belongs to this application. When not set, only
+# check the pid, but not what it is. This is only needed when multiple
+# applications need to share the same pid file.
+PIDFILE_CHECK_PID=true
+
+# FIXED_COMMAND tells the script to use a hard coded action rather than
+# expecting the first parameter of the command line to be the command.
+# By default the command will will be expected to be the first parameter.
+#FIXED_COMMAND=console
+
+# PASS_THROUGH tells the script to pass all arguments through to the JVM
+# as is. If FIXED_COMMAND is specified then all arguments will be passed.
+# If not set then all arguments starting with the second will be passed.
+PASS_THROUGH=true
+
+# If uncommented, causes the Wrapper to be shutdown using an anchor file.
+# When launched with the 'start' command, it will also ignore all INT and
+# TERM signals.
+#IGNORE_SIGNALS=true
+
+# Wrapper will start the JVM asynchronously. Your application may have some
+# initialization tasks and it may be desirable to wait a few seconds
+# before returning. For example, to delay the invocation of following
+# startup scripts. Setting WAIT_AFTER_STARTUP to a positive number will
+# cause the start command to delay for the indicated period of time
+# (in seconds).
+#
+WAIT_AFTER_STARTUP=0
+
+# If set, wait for the wrapper to report that the daemon has started
+WAIT_FOR_STARTED_STATUS=true
+WAIT_FOR_STARTED_TIMEOUT=120
+
+# If set, the status, start_msg and stop_msg commands will print out detailed
+# state information on the Wrapper and Java processes.
+#DETAIL_STATUS=true
+
+# If set, the 'pause' and 'resume' commands will be enabled. These make it
+# possible to pause the JVM or Java application without completely stopping
+# the Wrapper. See the wrapper.pausable and wrapper.pausable.stop_jvm
+# properties for more information.
+#PAUSABLE=true
+
+# If specified, the Wrapper will be run as the specified user.
+# IMPORTANT - Make sure that the user has the required privileges to write
+# the PID file and wrapper.log files. Failure to be able to write the log
+# file will cause the Wrapper to exit without any way to write out an error
+# message.
+# NOTE - This will set the user which is used to run the Wrapper as well as
+# the JVM and is not useful in situations where a privileged resource or
+# port needs to be allocated prior to the user being changed.
+#RUN_AS_USER=
+
+# Set the full path to the 'su' command (substitute user).
+# NOTE - In case 'su' is not in the PATH, you can set the absolute path here,
+# for example:
+# SU_BIN=/bin/su
+# NOTE - For Red Hat, the script will use '/sbin/runuser' if it is present and
+# ignore the value of SU_BIN.
+SU_BIN=su
+
+# Set option for 'su'.
+# In case the user set in RUN_AS_USER has no bash set, the 'su' command will fail.
+# The workaround for GNU/Linux system is to specify which bash to use with
+# the '-s' option.
+#SU_OPTS="-s /bin/bash"
+
+# Set the full path to the 'id' command.
+# For example:
+# ID_BIN=/usr/bin/id
+ID_BIN=id
+
+# By default we show a detailed usage block. Uncomment to show brief usage.
+#BRIEF_USAGE=true
+
+# OS service management tool: flag for using Upstart when installing (rather than init.d rc.d)
+USE_UPSTART=
+
+# OS service management tool: flag for using systemd when installing
+USE_SYSTEMD=
+
+# When installing on Mac OSX platforms, the following domain will be used to
+# prefix the plist file name.
+PLIST_DOMAIN=org.tanukisoftware.wrapper
+
+# When installing on Mac OSX platforms, this parameter controls whether the daemon
+# is to be kept continuously running or to let demand and conditions control the
+# invocation.
+MACOSX_KEEP_RUNNING="false"
+
+# The following two lines are used by the chkconfig command. Change as is
+# appropriate for your application. They should remain commented.
+# chkconfig: 2345 20 80
+# description: Test Wrapper Sample Application
+
+# Set run level to use when installing the application to start and stop on
+# system startup and shutdown. It is important that the application always
+# be uninstalled before making any changes to the run levels.
+# It is also possible to specify different run levels based on the individual
+# platform. When doing so this script will look for defined run levels in
+# the following order:
+# 1) "RUN_LEVEL_S_$DIST_OS" or "RUN_LEVEL_K_$DIST_OS", where "$DIST_OS" is
+# the value of DIST_OS. "RUN_LEVEL_S_solaris=20" for example.
+# 2) RUN_LEVEL_S or RUN_LEVEL_K, to specify specify start or stop run levels.
+# 3) RUN_LEVEL, to specify a general run level.
+RUN_LEVEL=20
+
+# Do not modify anything beyond this point
+#-----------------------------------------------------------------------------
+
+# check if we are running under Cygwin terminal.
+# Note: on some OS's (for example Solaris, MacOS), -o is not a valid parameter
+# and it shows an error message. We redirect stderr to null so the error message
+# doesn't show up.
+CYGWIN=`uname -o 2>/dev/null`
+if [ "$CYGWIN" = "Cygwin" ]
+then
+ eval echo `gettext 'This script is not compatible with Cygwin. Please use the Wrapper batch files to control the Wrapper.'`
+ exit 1
+fi
+
+if [ -n "$FIXED_COMMAND" ]
+then
+ COMMAND="$FIXED_COMMAND"
+else
+ COMMAND="$1"
+fi
+
+# check if there is a parameter "sysd"
+SYSD=
+if [ $# -gt 1 ] ; then
+ if [ $2 = "sysd" ] ; then
+ SYSD=1
+ fi
+fi
+
+# default location for the service file
+SYSTEMD_SERVICE_FILE="/etc/systemd/system/$APP_NAME.service"
+
+# Required for HP-UX Startup
+if [ `uname -s` = "HP-UX" -o `uname -s` = "HP-UX64" ] ; then
+ PATH=$PATH:/usr/bin
+fi
+
+# Get the fully qualified path to the script
+case $0 in
+ /*)
+ SCRIPT="$0"
+ ;;
+ *)
+ PWD=`pwd`
+ SCRIPT="$PWD/$0"
+ ;;
+esac
+
+# Resolve the true real path without any sym links.
+CHANGED=true
+while [ "X$CHANGED" != "X" ]
+do
+ # Change spaces to ":" so the tokens can be parsed.
+ SAFESCRIPT=`echo $SCRIPT | sed -e 's; ;:;g'`
+ # Get the real path to this script, resolving any symbolic links
+ TOKENS=`echo $SAFESCRIPT | sed -e 's;/; ;g'`
+ REALPATH=
+ for C in $TOKENS; do
+ # Change any ":" in the token back to a space.
+ C=`echo $C | sed -e 's;:; ;g'`
+ REALPATH="$REALPATH/$C"
+ # If REALPATH is a sym link, resolve it. Loop for nested links.
+ while [ -h "$REALPATH" ] ; do
+ LS="`ls -ld "$REALPATH"`"
+ LINK="`expr "$LS" : '.*-> \(.*\)$'`"
+ if expr "$LINK" : '/.*' > /dev/null; then
+ # LINK is absolute.
+ REALPATH="$LINK"
+ else
+ # LINK is relative.
+ REALPATH="`dirname "$REALPATH"`""/$LINK"
+ fi
+ done
+ done
+
+ if [ "$REALPATH" = "$SCRIPT" ]
+ then
+ CHANGED=""
+ else
+ SCRIPT="$REALPATH"
+ fi
+done
+
+# Get the location of the script.
+REALDIR=`dirname "$REALPATH"`
+# Normalize the path
+REALDIR=`cd "${REALDIR}"; pwd`
+
+# If the PIDDIR is relative, set its value relative to the full REALPATH to avoid problems if
+# the working directory is later changed.
+FIRST_CHAR=`echo $PIDDIR | cut -c1,1`
+if [ "$FIRST_CHAR" != "/" ]
+then
+ PIDDIR=$REALDIR/$PIDDIR
+fi
+# Same test for WRAPPER_CMD
+FIRST_CHAR=`echo $WRAPPER_CMD | cut -c1,1`
+if [ "$FIRST_CHAR" != "/" ]
+then
+ WRAPPER_CMD=$REALDIR/$WRAPPER_CMD
+fi
+# Same test for WRAPPER_CONF
+FIRST_CHAR=`echo $WRAPPER_CONF | cut -c1,1`
+if [ "$FIRST_CHAR" != "/" ]
+then
+ WRAPPER_CONF=$REALDIR/$WRAPPER_CONF
+fi
+
+# Process ID
+ANCHORFILE="$PIDDIR/$APP_NAME.anchor"
+COMMANDFILE="$PIDDIR/$APP_NAME.command"
+STATUSFILE="$PIDDIR/$APP_NAME.status"
+JAVASTATUSFILE="$PIDDIR/$APP_NAME.java.status"
+PIDFILE="$PIDDIR/$APP_NAME.pid"
+LOCKDIR="/var/lock/subsys"
+LOCKFILE="$LOCKDIR/$APP_NAME"
+pid=""
+
+# Resolve the location of the 'ps' command
+PS_BIN="/usr/ucb/ps"
+ if [ ! -x "$PS_BIN" ]
+ then
+ PS_BIN="/usr/bin/ps"
+ if [ ! -x "$PS_BIN" ]
+ then
+ PS_BIN="/bin/ps"
+ if [ ! -x "$PS_BIN" ]
+ then
+ eval echo `gettext 'Unable to locate "ps".'`
+ eval echo `gettext 'Please report this message along with the location of the command on your system.'`
+ exit 1
+ fi
+ fi
+ fi
+
+TR_BIN="/usr/bin/tr"
+if [ ! -x "$TR_BIN" ]
+then
+ TR_BIN="/bin/tr"
+ if [ ! -x "$TR_BIN" ]
+ then
+ eval echo `gettext 'Unable to locate "tr".'`
+ eval echo `gettext 'Please report this message along with the location of the command on your system.'`
+ exit 1
+ fi
+fi
+# Resolve the os
+DIST_OS=`uname -s | $TR_BIN "[A-Z]" "[a-z]" | $TR_BIN -d ' '`
+case "$DIST_OS" in
+ 'sunos')
+ DIST_OS="solaris"
+ ;;
+ 'hp-ux' | 'hp-ux64')
+ # HP-UX needs the XPG4 version of ps (for -o args)
+ DIST_OS="hpux"
+ UNIX95=""
+ export UNIX95
+ ;;
+ 'darwin')
+ DIST_OS="macosx"
+ ;;
+ 'unix_sv')
+ DIST_OS="unixware"
+ ;;
+ 'os/390')
+ DIST_OS="zos"
+ ;;
+esac
+
+# Compare Versions $1<$2=0, $1==$2=1, $1>$2=2
+compareVersions () {
+ if [ "$1" = "$2" ]
+ then
+ return 1
+ else
+ local i=1
+ while true
+ do
+ local v1=`echo "$1" | cut -d '.' -f $i`
+ local v2=`echo "$2" | cut -d '.' -f $i`
+ if [ "X$v1" = "X" ]
+ then
+ if [ "X$v2" = "X" ]
+ then
+ return 1
+ fi
+ v1="0"
+ elif [ "X$v2" = "X" ]
+ then
+ v2="0"
+ fi
+ if [ $v1 -lt $v2 ]
+ then
+ return 0
+ elif [ $v1 -gt $v2 ]
+ then
+ return 2
+ fi
+ i=`expr $i + 1`
+ done
+ fi
+}
+
+# Resolve the architecture
+if [ "$DIST_OS" = "macosx" ]
+then
+ OS_VER=`sw_vers | grep 'ProductVersion:' | grep -o '[0-9]*\.[0-9]*\.[0-9]*\|[0-9]*\.[0-9]*'`
+ DIST_ARCH="universal"
+ compareVersions "$OS_VER" "10.5.0"
+ if [[ $? < 1 ]]
+ then
+ DIST_BITS="32"
+ KEY_KEEP_ALIVE="OnDemand"
+ else
+ # Note: "OnDemand" has been deprecated and replaced from Mac OS X 10.5 by "KeepAlive"
+ KEY_KEEP_ALIVE="KeepAlive"
+
+ if [ "X`/usr/sbin/sysctl -n hw.cpu64bit_capable`" = "X1" ]
+ then
+ DIST_BITS="64"
+ else
+ DIST_BITS="32"
+ fi
+ fi
+ APP_PLIST_BASE=${PLIST_DOMAIN}.${APP_NAME}
+ APP_PLIST=${APP_PLIST_BASE}.plist
+else
+ if [ "$DIST_OS" = "linux" ]
+ then
+ DIST_ARCH=
+ else
+ DIST_ARCH=`uname -p 2>/dev/null | $TR_BIN "[A-Z]" "[a-z]" | $TR_BIN -d ' '`
+ fi
+ if [ "X$DIST_ARCH" = "X" ]
+ then
+ DIST_ARCH="unknown"
+ fi
+ if [ "$DIST_ARCH" = "unknown" ]
+ then
+ DIST_ARCH=`uname -m 2>/dev/null | $TR_BIN "[A-Z]" "[a-z]" | $TR_BIN -d ' '`
+ fi
+ case "$DIST_ARCH" in
+ 'athlon' | 'i386' | 'i486' | 'i586' | 'i686')
+ DIST_ARCH="x86"
+ if [ "${DIST_OS}" = "solaris" ] ; then
+ DIST_BITS=`isainfo -b`
+ else
+ DIST_BITS="32"
+ fi
+ ;;
+ 'amd64' | 'x86_64')
+ DIST_ARCH="x86"
+ DIST_BITS="64"
+ ;;
+ 'ia32')
+ DIST_ARCH="ia"
+ DIST_BITS="32"
+ ;;
+ 'ia64' | 'ia64n' | 'ia64w')
+ DIST_ARCH="ia"
+ DIST_BITS="64"
+ ;;
+ 'ip27')
+ DIST_ARCH="mips"
+ DIST_BITS="32"
+ ;;
+ 'power' | 'powerpc' | 'power_pc' | 'ppc64')
+ if [ "${DIST_ARCH}" = "ppc64" ] ; then
+ DIST_BITS="64"
+ else
+ DIST_BITS="32"
+ fi
+ DIST_ARCH="ppc"
+ if [ "${DIST_OS}" = "aix" ] ; then
+ if [ `getconf KERNEL_BITMODE` -eq 64 ]; then
+ DIST_BITS="64"
+ else
+ DIST_BITS="32"
+ fi
+ fi
+ ;;
+ 'pa_risc' | 'pa-risc')
+ DIST_ARCH="parisc"
+ if [ `getconf KERNEL_BITS` -eq 64 ]; then
+ DIST_BITS="64"
+ else
+ DIST_BITS="32"
+ fi
+ ;;
+ 'sun4u' | 'sparcv9' | 'sparc')
+ DIST_ARCH="sparc"
+ DIST_BITS=`isainfo -b`
+ ;;
+ '9000/800' | '9000/785')
+ DIST_ARCH="parisc"
+ if [ `getconf KERNEL_BITS` -eq 64 ]; then
+ DIST_BITS="64"
+ else
+ DIST_BITS="32"
+ fi
+ ;;
+ '2064' | '2066' | '2084' | '2086' | '2094' | '2096' | '2097' | '2098' | '2817')
+ DIST_ARCH="390"
+ DIST_BITS="64"
+ ;;
+ armv*)
+ if [ -z "`readelf -A /proc/self/exe | grep Tag_ABI_VFP_args`" ] ; then
+ DIST_ARCH="armel"
+ DIST_BITS="32"
+ else
+ DIST_ARCH="armhf"
+ DIST_BITS="32"
+ fi
+ ;;
+ esac
+fi
+
+# OSX always places Java in the same location so we can reliably set JAVA_HOME
+if [ "$DIST_OS" = "macosx" ]
+then
+ if [ -z "$JAVA_HOME" ]; then
+ if [ -x /usr/libexec/java_home ]; then
+ JAVA_HOME=`/usr/libexec/java_home`; export JAVA_HOME
+ else
+ JAVA_HOME="/Library/Java/Home"; export JAVA_HOME
+ fi
+ fi
+fi
+
+# Test Echo
+ECHOTEST=`echo -n "x"`
+if [ "$ECHOTEST" = "x" ]
+then
+ ECHOOPT="-n "
+ ECHOOPTC=""
+else
+ ECHOOPT=""
+ ECHOOPTC="\c"
+fi
+
+
+gettext() {
+ "$WRAPPER_CMD" --translate "$1" "$WRAPPER_CONF" 2>/dev/null
+ if [ $? != 0 ] ; then
+ echo "$1"
+ fi
+}
+
+outputFile() {
+ if [ -f "$1" ]
+ then
+ eval echo `gettext ' $1 Found but not executable.'`;
+ else
+ echo " $1"
+ fi
+}
+
+# Decide on the wrapper binary to use.
+# If the bits of the OS could be detected, we will try to look for the
+# binary with the correct bits value. If it doesn't exist, fall back
+# and look for the 32-bit binary. If that doesn't exist either then
+# look for the default.
+WRAPPER_TEST_CMD=""
+if [ -f "$WRAPPER_CMD-$DIST_OS-$DIST_ARCH-$DIST_BITS" ]
+then
+ WRAPPER_TEST_CMD="$WRAPPER_CMD-$DIST_OS-$DIST_ARCH-$DIST_BITS"
+ if [ ! -x "$WRAPPER_TEST_CMD" ]
+ then
+ chmod +x "$WRAPPER_TEST_CMD" 2>/dev/null
+ fi
+ if [ -x "$WRAPPER_TEST_CMD" ]
+ then
+ WRAPPER_CMD="$WRAPPER_TEST_CMD"
+ else
+ outputFile "$WRAPPER_TEST_CMD"
+ WRAPPER_TEST_CMD=""
+ fi
+fi
+if [ -f "$WRAPPER_CMD-$DIST_OS-$DIST_ARCH-32" -a -z "$WRAPPER_TEST_CMD" ]
+then
+ WRAPPER_TEST_CMD="$WRAPPER_CMD-$DIST_OS-$DIST_ARCH-32"
+ if [ ! -x "$WRAPPER_TEST_CMD" ]
+ then
+ chmod +x "$WRAPPER_TEST_CMD" 2>/dev/null
+ fi
+ if [ -x "$WRAPPER_TEST_CMD" ]
+ then
+ WRAPPER_CMD="$WRAPPER_TEST_CMD"
+ else
+ outputFile "$WRAPPER_TEST_CMD"
+ WRAPPER_TEST_CMD=""
+ fi
+fi
+if [ -f "$WRAPPER_CMD" -a -z "$WRAPPER_TEST_CMD" ]
+then
+ WRAPPER_TEST_CMD="$WRAPPER_CMD"
+ if [ ! -x "$WRAPPER_TEST_CMD" ]
+ then
+ chmod +x "$WRAPPER_TEST_CMD" 2>/dev/null
+ fi
+ if [ -x "$WRAPPER_TEST_CMD" ]
+ then
+ WRAPPER_CMD="$WRAPPER_TEST_CMD"
+ else
+ outputFile "$WRAPPER_TEST_CMD"
+ WRAPPER_TEST_CMD=""
+ fi
+fi
+if [ -z "$WRAPPER_TEST_CMD" ]
+then
+ eval echo `gettext 'Unable to locate any of the following binaries:'`
+ outputFile "$WRAPPER_CMD-$DIST_OS-$DIST_ARCH-$DIST_BITS"
+ if [ ! "$DIST_BITS" = "32" ]
+ then
+ outputFile "$WRAPPER_CMD-$DIST_OS-$DIST_ARCH-32"
+ fi
+ outputFile "$WRAPPER_CMD"
+
+ exit 1
+fi
+
+
+# Build the nice clause
+if [ "X$PRIORITY" = "X" ]
+then
+ CMDNICE=""
+else
+ CMDNICE="nice -$PRIORITY"
+fi
+
+# Build the anchor file clause.
+if [ "X$IGNORE_SIGNALS" = "X" ]
+then
+ ANCHORPROP=
+ IGNOREPROP=
+else
+ ANCHORPROP=wrapper.anchorfile=\"$ANCHORFILE\"
+ IGNOREPROP=wrapper.ignore_signals=TRUE
+fi
+
+# Build the status file clause.
+if [ "X$DETAIL_STATUS$WAIT_FOR_STARTED_STATUS" = "X" ]
+then
+ STATUSPROP=
+else
+ STATUSPROP="wrapper.statusfile=\"$STATUSFILE\" wrapper.java.statusfile=\"$JAVASTATUSFILE\""
+fi
+
+# Build the command file clause.
+if [ -n "$PAUSABLE" ]
+then
+ COMMANDPROP="wrapper.commandfile=\"$COMMANDFILE\" wrapper.pausable=TRUE"
+else
+ COMMANDPROP=
+fi
+
+if [ ! -n "$WAIT_FOR_STARTED_STATUS" ]
+then
+ WAIT_FOR_STARTED_STATUS=true
+fi
+
+if [ $WAIT_FOR_STARTED_STATUS = true ] ; then
+ DETAIL_STATUS=true
+fi
+
+
+# Build the lock file clause. Only create a lock file if the lock directory exists on this platform.
+LOCKPROP=
+if [ -d $LOCKDIR ]
+then
+ if [ -w $LOCKDIR ]
+ then
+ LOCKPROP=wrapper.lockfile=\"$LOCKFILE\"
+ fi
+fi
+
+# Build app name clause
+if [ ! -n "$APP_NAME_PASS_TO_WRAPPER" ]
+then
+ APP_NAME_PASS_TO_WRAPPER=true
+fi
+if [ $APP_NAME_PASS_TO_WRAPPER = false ]
+then
+ APPNAMEPROP=
+else
+ APPNAMEPROP="wrapper.name=\"$APP_NAME\" wrapper.displayname=\"$APP_LONG_NAME\""
+fi
+
+# Decide on run levels.
+RUN_LEVEL_S_DIST_OS_TMP=`eval "echo \$\{RUN_LEVEL_S_${DIST_OS}\}"`
+RUN_LEVEL_S_DIST_OS=`eval "echo ${RUN_LEVEL_S_DIST_OS_TMP}"`
+if [ "X${RUN_LEVEL_S_DIST_OS}" != "X" ] ; then
+ APP_RUN_LEVEL_S=${RUN_LEVEL_S_DIST_OS}
+elif [ "X$RUN_LEVEL_S" != "X" ] ; then
+ APP_RUN_LEVEL_S=$RUN_LEVEL_S
+else
+ APP_RUN_LEVEL_S=$RUN_LEVEL
+fi
+APP_RUN_LEVEL_S_CHECK=`echo "$APP_RUN_LEVEL_S" | sed "s/[(0-9)*]/0/g"`
+if [ "X${APP_RUN_LEVEL_S_CHECK}" != "X00" ] ; then
+ eval echo `gettext 'Run level \"${APP_RUN_LEVEL_S}\" must be numeric and have a length of two \(00-99\).'`
+ exit 1;
+fi
+RUN_LEVEL_K_DIST_OS_TMP=`eval "echo \$\{RUN_LEVEL_K_${DIST_OS}\}"`
+RUN_LEVEL_K_DIST_OS=`eval "echo ${RUN_LEVEL_K_DIST_OS_TMP}"`
+if [ "X${RUN_LEVEL_K_DIST_OS}" != "X" ] ; then
+ APP_RUN_LEVEL_K=${RUN_LEVEL_K_DIST_OS}
+elif [ "X$RUN_LEVEL_K" != "X" ] ; then
+ APP_RUN_LEVEL_K=$RUN_LEVEL_K
+else
+ APP_RUN_LEVEL_K=$RUN_LEVEL
+fi
+APP_RUN_LEVEL_K_CHECK=`echo "$APP_RUN_LEVEL_K" | sed "s/[(0-9)*]/0/g"`
+if [ "X${APP_RUN_LEVEL_K_CHECK}" != "X00" ] ; then
+ eval echo `gettext 'Run level \"${APP_RUN_LEVEL_K}\" must be numeric and have a length of two \(00-99\).'`
+ exit 1;
+fi
+
+prepAdditionalParams() {
+ ADDITIONAL_PARA=""
+ if [ ! -n "$PASS_THROUGH" ]
+ then
+ PASS_THROUGH=false
+ fi
+ if [ $PASS_THROUGH = true ] ; then
+ ADDITIONAL_PARA="--"
+ while [ -n "$1" ] ; do
+ ADDITIONAL_PARA="$ADDITIONAL_PARA \"$1\""
+ shift
+ done
+ elif [ -n "$1" ] ; then
+ eval echo `gettext "WARNING: Extra arguments will be ignored. Please run \'$0 help\' for usage."`
+ fi
+}
+
+checkUser() {
+ # $1 touchLock flag
+ # $2.. [command] args
+
+ # Check the configured user. If necessary rerun this script as the desired user.
+ if [ "X$RUN_AS_USER" != "X" ]
+ then
+ # Resolve the location of the 'id' command
+ ID_BIN="/usr/xpg4/bin/id"
+ if [ ! -x "$ID_BIN" ]
+ then
+ ID_BIN="/usr/bin/id"
+ if [ ! -x "$ID_BIN" ]
+ then
+ eval echo `gettext 'Unable to locate "id".'`
+ eval echo `gettext 'Please report this message along with the location of the command on your system.'`
+ exit 1
+ fi
+ fi
+
+ if [ "`$ID_BIN -u -n`" = "$RUN_AS_USER" ]
+ then
+ # Already running as the configured user. Avoid password prompts by not calling su.
+ RUN_AS_USER=""
+ fi
+ fi
+ if [ "X$RUN_AS_USER" != "X" ]
+ then
+ if [ "`$ID_BIN -u -n "$RUN_AS_USER" 2>/dev/null`" != "$RUN_AS_USER" ]
+ then
+ eval echo `gettext 'User $RUN_AS_USER does not exist.'`
+ exit 1
+ fi
+
+ # If LOCKPROP and $RUN_AS_USER are defined then the new user will most likely not be
+ # able to create the lock file. The Wrapper will be able to update this file once it
+ # is created but will not be able to delete it on shutdown. If $1 is set then
+ # the lock file should be created for the current command
+ if [ "X$LOCKPROP" != "X" ]
+ then
+ if [ "X$1" != "X" ]
+ then
+ # Resolve the primary group
+ RUN_AS_GROUP=`groups $RUN_AS_USER | awk '{print $3}' | tail -1`
+ if [ "X$RUN_AS_GROUP" = "X" ]
+ then
+ RUN_AS_GROUP=$RUN_AS_USER
+ fi
+ touch $LOCKFILE
+ chown $RUN_AS_USER:$RUN_AS_GROUP $LOCKFILE
+ fi
+ fi
+
+ # Still want to change users, recurse. This means that the user will only be
+ # prompted for a password once. Variables shifted by 1
+ shift
+
+ # Wrap the parameters so they can be passed.
+ ADDITIONAL_PARA=""
+ while [ -n "$1" ] ; do
+ if [ "$1" = 'installstart' ] ; then
+ # At this point the service is already installed. When we will fork the process we only need to start the service.
+ ADDITIONAL_PARA="$ADDITIONAL_PARA \"start\""
+ else
+ ADDITIONAL_PARA="$ADDITIONAL_PARA \"$1\""
+ fi
+ shift
+ done
+
+ # Use "runuser" if this exists.
+ # runuser should be used on RedHat in preference to su.
+ if test -f "/sbin/runuser"
+ then
+ /sbin/runuser - $RUN_AS_USER -c "\"$REALPATH\" $ADDITIONAL_PARA"
+ else
+ $SU_BIN - $RUN_AS_USER -c "\"$REALPATH\" $ADDITIONAL_PARA" $SU_OPTS
+ fi
+ RUN_AS_USER_EXITCODE=$?
+
+ # we check if the previous command has failed
+ if [ $RUN_AS_USER_EXITCODE -ne 0 ]
+ then
+ if [ $RUN_AS_USER_EXITCODE -eq 1 ]
+ then
+ checkForkCommand
+ else
+ eval echo `gettext 'Error executing the requested command with user \"$RUN_AS_USER\" \(error code $RUN_AS_USER_EXITCODE\).'`
+ echo ""
+ fi
+ fi
+
+ # Now that we are the original user again, we may need to clean up the lock file.
+ if [ "X$LOCKPROP" != "X" ]
+ then
+ getpid
+ if [ "X$pid" = "X" ]
+ then
+ # Wrapper is not running so make sure the lock file is deleted.
+ if [ -f "$LOCKFILE" ]
+ then
+ rm "$LOCKFILE"
+ fi
+ fi
+ fi
+
+ exit $RUN_AS_USER_EXITCODE
+ fi
+}
+
+# Try to fork by executing a simple command.
+# With this function, we want to make sure we are able to fork.
+checkForkCommand() {
+
+ if test -f "/sbin/runuser"
+ then
+ /sbin/runuser - $RUN_AS_USER -c "ls \"$REALPATH\"" > /dev/null 2>&1 &
+ else
+ $SU_BIN - $RUN_AS_USER -c "ls \"$REALPATH\"" $SU_OPTS > /dev/null 2>&1 &
+ fi
+ CHECK_EXITCODE=$?
+
+ if [ $CHECK_EXITCODE -ne 0 ]
+ then
+ # clearly a problem with forking
+ eval echo `gettext 'Error: unable to create fork process.'`
+ eval echo `gettext 'Advice:'`
+ eval echo `gettext 'One possible cause of failure is when the user \(\"$RUN_AS_USER\"\) has no shell.'`
+ eval echo `gettext 'In this case, two solutions are available by editing the script file:'`
+ eval echo `gettext '1. Use \"SU_OPTS\" to set the shell for the user.'`
+ eval echo `gettext '2. Use a OS service management tool (only available on some platforms).'`
+ echo ""
+ fi
+}
+
+getpid() {
+ pid=""
+ if [ -f "$PIDFILE" ]
+ then
+ if [ -r "$PIDFILE" ]
+ then
+ pid=`cat "$PIDFILE"`
+ if [ "X$pid" != "X" ]
+ then
+ if [ "X$PIDFILE_CHECK_PID" != "X" ]
+ then
+ # It is possible that 'a' process with the pid exists but that it is not the
+ # correct process. This can happen in a number of cases, but the most
+ # common is during system startup after an unclean shutdown.
+ # The ps statement below looks for the specific wrapper command running as
+ # the pid. If it is not found then the pid file is considered to be stale.
+ case "$DIST_OS" in
+ 'freebsd')
+ pidtest=`$PS_BIN -p $pid -o args | tail -1`
+ if [ "X$pidtest" = "XCOMMAND" ]
+ then
+ pidtest=""
+ fi
+ ;;
+ 'macosx')
+ pidtest=`$PS_BIN -ww -p $pid -o command | grep -F "$WRAPPER_CMD" | tail -1`
+ ;;
+ 'solaris')
+ if [ -f "/usr/bin/pargs" ]
+ then
+ pidtest=`pargs $pid | fgrep "$WRAPPER_CMD" | tail -1`
+ else
+ case "$PS_BIN" in
+ '/usr/ucb/ps')
+ pidtest=`$PS_BIN -auxww $pid | fgrep "$WRAPPER_CMD" | tail -1`
+ ;;
+ '/usr/bin/ps')
+ TRUNCATED_CMD=`$PS_BIN -o comm -p $pid | tail -1`
+ COUNT=`echo $TRUNCATED_CMD | wc -m`
+ COUNT=`echo ${COUNT}`
+ COUNT=`expr $COUNT - 1`
+ TRUNCATED_CMD=`echo $WRAPPER_CMD | cut -c1-$COUNT`
+ pidtest=`$PS_BIN -o comm -p $pid | fgrep "$TRUNCATED_CMD" | tail -1`
+ ;;
+ '/bin/ps')
+ TRUNCATED_CMD=`$PS_BIN -o comm -p $pid | tail -1`
+ COUNT=`echo $TRUNCATED_CMD | wc -m`
+ COUNT=`echo ${COUNT}`
+ COUNT=`expr $COUNT - 1`
+ TRUNCATED_CMD=`echo $WRAPPER_CMD | cut -c1-$COUNT`
+ pidtest=`$PS_BIN -o comm -p $pid | fgrep "$TRUNCATED_CMD" | tail -1`
+ ;;
+ *)
+ echo "Unsupported ps command $PS_BIN"
+ exit 1
+ ;;
+ esac
+ fi
+ ;;
+ 'hpux')
+ pidtest=`$PS_BIN -p $pid -x -o args | grep -F "$WRAPPER_CMD" | tail -1`
+ ;;
+ 'zos')
+ TRUNCATED_CMD=`$PS_BIN -p $pid -o args | tail -1`
+ COUNT=`echo $TRUNCATED_CMD | wc -m`
+ COUNT=`echo ${COUNT}`
+ COUNT=`expr $COUNT - 1`
+ TRUNCATED_CMD=`echo $WRAPPER_CMD | cut -c1-$COUNT`
+ pidtest=`$PS_BIN -p $pid -o args | grep -F "$TRUNCATED_CMD" | tail -1`
+ ;;
+ *)
+ pidtest=`$PS_BIN -p $pid -o args | grep -F "$WRAPPER_CMD" | tail -1`
+ ;;
+ esac
+ else
+ # Check to see whether the pid exists as a running process, but in this mode, don't check what that pid is.
+ case "$DIST_OS" in
+ 'solaris')
+ case "$PS_BIN" in
+ '/usr/ucb/ps')
+ pidtest=`$PS_BIN $pid | grep "$pid" | awk '{print $1}' | tail -1`
+ ;;
+ '/usr/bin/ps')
+ pidtest=`$PS_BIN -p $pid -o pid | grep "$pid" | tail -1`
+ ;;
+ '/bin/ps')
+ pidtest=`$PS_BIN -p $pid -o pid | grep "$pid" | tail -1`
+ ;;
+ *)
+ echo "Unsupported ps command $PS_BIN"
+ exit 1
+ ;;
+ esac
+ ;;
+ *)
+ pidtest=`$PS_BIN -p $pid -o pid | grep "$pid" | tail -1`
+ ;;
+ esac
+ fi
+
+ if [ "X$pidtest" = "X" ]
+ then
+ # This is a stale pid file.
+ rm -f "$PIDFILE"
+ eval echo `gettext 'Removed stale pid file: $PIDFILE'`
+ pid=""
+ fi
+ fi
+ else
+ eval echo `gettext 'Cannot read $PIDFILE.'`
+ exit 1
+ fi
+ fi
+}
+
+getstatus() {
+ STATUS=
+ if [ -f "$STATUSFILE" ]
+ then
+ if [ -r "$STATUSFILE" ]
+ then
+ STATUS=`cat "$STATUSFILE"`
+ fi
+ fi
+ if [ "X$STATUS" = "X" ]
+ then
+ STATUS="Unknown"
+ fi
+
+ JAVASTATUS=
+ if [ -f "$JAVASTATUSFILE" ]
+ then
+ if [ -r "$JAVASTATUSFILE" ]
+ then
+ JAVASTATUS=`cat "$JAVASTATUSFILE"`
+ fi
+ fi
+ if [ "X$JAVASTATUS" = "X" ]
+ then
+ JAVASTATUS="Unknown"
+ fi
+}
+
+testpid() {
+ case "$DIST_OS" in
+ 'solaris')
+ case "$PS_BIN" in
+ '/usr/ucb/ps')
+ pid=`$PS_BIN $pid | grep $pid | grep -v grep | awk '{print $1}' | tail -1`
+ ;;
+ '/usr/bin/ps')
+ pid=`$PS_BIN -p $pid | grep $pid | grep -v grep | awk '{print $1}' | tail -1`
+ ;;
+ '/bin/ps')
+ pid=`$PS_BIN -p $pid | grep $pid | grep -v grep | awk '{print $1}' | tail -1`
+ ;;
+ *)
+ echo "Unsupported ps command $PS_BIN"
+ exit 1
+ ;;
+ esac
+ ;;
+ *)
+ pid=`$PS_BIN -p $pid | grep $pid | grep -v grep | awk '{print $1}' | tail -1` 2>/dev/null
+ ;;
+ esac
+ if [ "X$pid" = "X" ]
+ then
+ # Process is gone so remove the pid file.
+ rm -f "$PIDFILE"
+ pid=""
+ fi
+}
+
+launchdtrap() {
+ stopit
+ exit
+}
+
+waitforwrapperstop() {
+ getpid
+ while [ "X$pid" != "X" ] ; do
+ sleep 1
+ getpid
+ done
+}
+
+launchinternal() {
+ getpid
+ trap launchdtrap TERM
+ if [ "X$pid" = "X" ]
+ then
+ prepAdditionalParams "$@"
+
+ # The string passed to eval must handles spaces in paths correctly.
+ COMMAND_LINE="$CMDNICE \"$WRAPPER_CMD\" \"$WRAPPER_CONF\" wrapper.syslog.ident=\"$APP_NAME\" wrapper.pidfile=\"$PIDFILE\" wrapper.daemonize=TRUE $APPNAMEPROP $ANCHORPROP $IGNOREPROP $STATUSPROP $COMMANDPROP $LOCKPROP wrapper.script.version=3.5.28 $ADDITIONAL_PARA"
+ eval $COMMAND_LINE
+ else
+ eval echo `gettext '$APP_LONG_NAME is already running.'`
+ exit 1
+ fi
+ # launchd expects that this script stay up and running so we need to do our own monitoring of the Wrapper process.
+ if [ $WAIT_FOR_STARTED_STATUS = true ]
+ then
+ waitforwrapperstop
+ fi
+}
+
+console() {
+ eval echo `gettext 'Running $APP_LONG_NAME...'`
+ getpid
+ if [ "X$pid" = "X" ]
+ then
+ trap '' 3
+
+ prepAdditionalParams "$@"
+
+ # The string passed to eval must handles spaces in paths correctly.
+ COMMAND_LINE="$CMDNICE \"$WRAPPER_CMD\" \"$WRAPPER_CONF\" wrapper.syslog.ident=\"$APP_NAME\" wrapper.pidfile=\"$PIDFILE\" $APPNAMEPROP $ANCHORPROP $STATUSPROP $COMMANDPROP $LOCKPROP wrapper.script.version=3.5.28 $ADDITIONAL_PARA"
+ eval $COMMAND_LINE
+ else
+ eval echo `gettext '$APP_LONG_NAME is already running.'`
+ exit 1
+ fi
+}
+
+waitforjavastartup() {
+ getstatus
+ eval echo $ECHOOPT `gettext 'Waiting for $APP_LONG_NAME...$ECHOOPTC'`
+
+ # Wait until the timeout or we have something besides Unknown.
+ counter=15
+ while [ "$JAVASTATUS" = "Unknown" -a $counter -gt 0 -a -n "$JAVASTATUS" ] ; do
+ echo $ECHOOPT".$ECHOOPTC"
+ sleep 1
+ getstatus
+ counter=`expr $counter - 1`
+ done
+
+ if [ -n "$WAIT_FOR_STARTED_TIMEOUT" ] ; then
+ counter=$WAIT_FOR_STARTED_TIMEOUT
+ else
+ counter=120
+ fi
+ while [ "$JAVASTATUS" != "STARTED" -a "$JAVASTATUS" != "Unknown" -a $counter -gt 0 -a -n "$JAVASTATUS" ] ; do
+ echo $ECHOOPT".$ECHOOPTC"
+ sleep 1
+ getstatus
+ counter=`expr $counter - 1`
+ done
+ echo ""
+}
+
+startwait() {
+ if [ $WAIT_FOR_STARTED_STATUS = true ]
+ then
+ waitforjavastartup
+ fi
+ # Sleep for a few seconds to allow for intialization if required
+ # then test to make sure we're still running.
+ #
+ i=0
+ while [ $i -lt $WAIT_AFTER_STARTUP ]
+ do
+ sleep 1
+ echo $ECHOOPT".$ECHOOPTC"
+ i=`expr $i + 1`
+ done
+ if [ $WAIT_AFTER_STARTUP -gt 0 -o $WAIT_FOR_STARTED_STATUS = true ]
+ then
+ getpid
+ if [ "X$pid" = "X" ]
+ then
+ eval echo `gettext ' WARNING: $APP_LONG_NAME may have failed to start.'`
+ exit 1
+ else
+ eval echo `gettext ' running: PID:$pid'`
+ fi
+ else
+ echo ""
+ fi
+}
+
+mustBeRootOrExit() {
+ if [ `id | sed 's/^uid=//;s/(.*$//'` != "0" ] ; then
+ eval echo `gettext 'Must be root to perform this action.'`
+ exit 1
+ fi
+}
+
+
+macosxStart() {
+ # The daemon has been installed.
+ eval echo `gettext 'Starting $APP_LONG_NAME. Detected Mac OSX and installed launchd daemon.'`
+ mustBeRootOrExit
+
+ getpid
+ if [ "X$pid" != "X" ] ; then
+ eval echo `gettext '$APP_LONG_NAME is already running.'`
+ exit 1
+ fi
+
+ # If the daemon was just installed, it may not be loaded.
+ LOADED_PLIST=`launchctl list | grep ${APP_PLIST_BASE}`
+ if [ "X${LOADED_PLIST}" = "X" ] ; then
+ launchctl load /Library/LaunchDaemons/${APP_PLIST}
+ fi
+ # If launchd is set to run the daemon already at Load, we don't need to call start
+ getpid
+ if [ "X$pid" = "X" ] ; then
+ launchctl start ${APP_PLIST_BASE}
+ fi
+
+ startwait
+}
+
+macosxStop() {
+ # The daemon should be running.
+ eval echo `gettext 'Stopping $APP_LONG_NAME...'`
+ mustBeRootOrExit
+
+ getpid
+ if [ "X$pid" = "X" ] ; then
+ eval echo `gettext '$APP_LONG_NAME is not running.'`
+ exit 1
+ else
+ if [ "$MACOSX_KEEP_RUNNING" = "true" ] ; then
+ echo ""
+ eval echo `gettext 'Daemon is set to be kept continuously running and it will be automatically restarted.'`
+ eval echo `gettext 'To stop the daemon you need to uninstall it.'`
+ eval echo `gettext 'If you want to use the \"stop\" argument, you need to find MACOSX_KEEP_RUNNING'`
+ eval echo `gettext 'at the beginning of the script file and set it to \"false\".'`
+ echo ""
+ fi
+ launchctl stop ${APP_PLIST_BASE}
+ fi
+}
+
+macosxRestart() {
+ # The daemon should be running.
+ eval echo `gettext 'Restarting $APP_LONG_NAME...'`
+ mustBeRootOrExit
+
+ getpid
+ if [ "X$pid" = "X" ] ; then
+ eval echo `gettext '$APP_LONG_NAME is not running.'`
+ exit 1
+ else
+ if [ "$MACOSX_KEEP_RUNNING" = "true" ] ; then
+ # by stopping it, launchd will automatically restart it
+ launchctl stop ${APP_PLIST_BASE}
+ else
+ launchctl unload "/Library/LaunchDaemons/${APP_PLIST}"
+ sleep 1
+ launchctl load "/Library/LaunchDaemons/${APP_PLIST}"
+ fi
+ fi
+
+ startwait
+}
+
+upstartstart() {
+ # The daemon has been installed.
+ eval echo `gettext 'Starting $APP_LONG_NAME. Detected Linux and installed upstart.'`
+ mustBeRootOrExit
+
+ getpid
+ if [ "X$pid" != "X" ] ; then
+ eval echo `gettext '$APP_LONG_NAME is already running.'`
+ exit 1
+ fi
+
+ /sbin/start ${APP_NAME}
+
+ startwait
+}
+
+upstartStop() {
+ # The daemon has been installed.
+ eval echo `gettext 'Stopping $APP_LONG_NAME...'`
+ mustBeRootOrExit
+
+ getpid
+ if [ "X$pid" = "X" ] ; then
+ eval echo `gettext '$APP_LONG_NAME is not running.'`
+ exit 1
+ fi
+
+ /sbin/stop ${APP_NAME}
+}
+
+upstartRestart() {
+ # The daemon has been installed.
+ eval echo `gettext 'Restarting $APP_LONG_NAME...'`
+ mustBeRootOrExit
+
+ getpid
+ if [ "X$pid" = "X" ] ; then
+ eval echo `gettext '$APP_LONG_NAME is not running.'`
+ exit 1
+ fi
+
+ /sbin/restart ${APP_NAME}
+
+ startwait
+}
+
+systemdInstall() {
+ eval echo `gettext ' Installing the $APP_LONG_NAME daemon using systemd...'`
+ if [ -f "${REALDIR}/${APP_NAME}.service" ] ; then
+ eval echo `gettext ' a custom service file ${APP_NAME}.service found'`
+ cp "${REALDIR}/${APP_NAME}.service" "${SYSTEMD_SERVICE_FILE}"
+ else
+ eval echo `gettext ' creating default service file...'`
+ echo "[Unit]" > "${SYSTEMD_SERVICE_FILE}"
+ echo "Description=${APP_LONG_NAME}" >> "${SYSTEMD_SERVICE_FILE}"
+ echo "After=syslog.target" >> "${SYSTEMD_SERVICE_FILE}"
+ echo "" >> "${SYSTEMD_SERVICE_FILE}"
+ echo "[Service]" >> "${SYSTEMD_SERVICE_FILE}"
+ echo "Type=forking" >> "${SYSTEMD_SERVICE_FILE}"
+ echo "ExecStart=${REALPATH} start sysd" >> "${SYSTEMD_SERVICE_FILE}"
+ echo "ExecStop=${REALPATH} stop sysd" >> "${SYSTEMD_SERVICE_FILE}"
+ if [ "X${RUN_AS_USER}" != "X" ] ; then
+ echo "User=${RUN_AS_USER}" >> "${SYSTEMD_SERVICE_FILE}"
+ fi
+ echo "" >> "${SYSTEMD_SERVICE_FILE}"
+ echo "[Install]" >> "${SYSTEMD_SERVICE_FILE}"
+ echo "WantedBy=multi-user.target" >> "${SYSTEMD_SERVICE_FILE}"
+
+ systemctl daemon-reload
+ systemctl enable "${APP_NAME}"
+ fi
+}
+
+systemdStart() {
+ # check if the service file is present
+ if [ -f "${SYSTEMD_SERVICE_FILE}" ] ; then
+ eval echo `gettext 'Reading file ${SYSTEMD_SERVICE_FILE}'`
+ else
+ eval echo `gettext 'No service file detected. Did you install the service?'`
+ exit 1
+ fi
+
+ systemctl start $APP_NAME
+ if [ $? -ne 0 ] ; then
+ eval echo `gettext 'Failed to start service $APP_NAME'`
+ exit 1
+ fi
+
+ startwait
+}
+
+systemdStop() {
+ systemctl stop $APP_NAME
+ if [ $? -ne 0 ] ; then
+ eval echo `gettext 'Failed to stop service $APP_NAME'`
+ exit 1
+ fi
+}
+
+systemdRestart() {
+ systemctl restart $APP_NAME
+ if [ $? -ne 0 ] ; then
+ eval echo `gettext 'Failed to restart service $APP_NAME'`
+ exit 1
+ fi
+
+ startwait
+}
+
+systemdRemove() {
+ stopit "0"
+ eval echo `gettext ' Removing $APP_LONG_NAME daemon from systemd...'`
+ systemctl disable $APP_NAME
+ rm "/etc/systemd/system/${APP_NAME}.service"
+ systemctl daemon-reload
+}
+
+srcInstall() {
+ if [ "X$RUN_AS_USER" = "X" ] ; then
+ USERID="0"
+ else
+ USERID=`$ID_BIN -u "$RUN_AS_USER"`
+ if [ $? -ne 0 ] ; then
+ eval echo `gettext 'Failed to get user id for $RUN_AS_USER'`
+ exit 1
+ fi
+ fi
+ /usr/bin/mkssys -s "$APP_NAME" -p "$REALPATH" -a "launchdinternal" -u "$USERID" -f 9 -n 15 -S
+ /usr/sbin/mkitab "$APP_NAME":2:once:"/usr/bin/startsrc -s \"${APP_NAME}\" >/dev/console 2>&1"
+}
+
+srcStart() {
+ startsrc -s "${APP_NAME}"
+ if [ $? -ne 0 ] ; then
+ eval echo `gettext 'Failed to start service $APP_NAME'`
+ exit 1
+ fi
+
+ startwait
+}
+
+srcStop() {
+ stopsrc -s "${APP_NAME}"
+ if [ $? -ne 0 ] ; then
+ eval echo `gettext 'Failed to stop service $APP_NAME'`
+ exit 1
+ fi
+}
+
+srcRestart() {
+ srcStop
+ srcStart
+}
+
+start() {
+ eval echo `gettext 'Starting $APP_LONG_NAME...'`
+ getpid
+ if [ "X$pid" = "X" ]
+ then
+ prepAdditionalParams "$@"
+
+ # The string passed to eval must handles spaces in paths correctly.
+ COMMAND_LINE="$CMDNICE \"$WRAPPER_CMD\" \"$WRAPPER_CONF\" wrapper.syslog.ident=\"$APP_NAME\" wrapper.pidfile=\"$PIDFILE\" wrapper.daemonize=TRUE $APPNAMEPROP $ANCHORPROP $IGNOREPROP $STATUSPROP $COMMANDPROP $LOCKPROP wrapper.script.version=3.5.28 $ADDITIONAL_PARA"
+ eval $COMMAND_LINE
+ else
+ eval echo `gettext '$APP_LONG_NAME is already running.'`
+ exit 1
+ fi
+
+ startwait
+}
+
+stopit() {
+ # $1 exit if down flag
+
+ eval echo `gettext 'Stopping $APP_LONG_NAME...'`
+ getpid
+ if [ "X$pid" = "X" ]
+ then
+ eval echo `gettext '$APP_LONG_NAME was not running.'`
+ if [ "X$1" = "X1" ]
+ then
+ exit 1
+ fi
+ else
+ if [ "X$IGNORE_SIGNALS" = "X" ]
+ then
+ # Running so try to stop it.
+ kill $pid
+ if [ $? -ne 0 ]
+ then
+ # An explanation for the failure should have been given
+ eval echo `gettext 'Unable to stop $APP_LONG_NAME.'`
+ exit 1
+ fi
+ else
+ rm -f "$ANCHORFILE"
+ if [ -f "$ANCHORFILE" ]
+ then
+ # An explanation for the failure should have been given
+ eval echo `gettext 'Unable to stop $APP_LONG_NAME.'`
+ exit 1
+ fi
+ fi
+
+ # We can not predict how long it will take for the wrapper to
+ # actually stop as it depends on settings in wrapper.conf.
+ # Loop until it does.
+ savepid=$pid
+ CNT=0
+ TOTCNT=0
+ while [ "X$pid" != "X" ]
+ do
+ # Show a waiting message every 5 seconds.
+ if [ "$CNT" -lt "5" ]
+ then
+ CNT=`expr $CNT + 1`
+ else
+ eval echo `gettext 'Waiting for $APP_LONG_NAME to exit...'`
+ CNT=0
+ fi
+ TOTCNT=`expr $TOTCNT + 1`
+
+ sleep 1
+
+ testpid
+ done
+
+ pid=$savepid
+ testpid
+ if [ "X$pid" != "X" ]
+ then
+ eval echo `gettext 'Failed to stop $APP_LONG_NAME.'`
+ exit 1
+ else
+ eval echo `gettext 'Stopped $APP_LONG_NAME.'`
+ fi
+ fi
+}
+
+pause() {
+ eval echo `gettext 'Pausing $APP_LONG_NAME.'`
+}
+
+resume() {
+ eval echo `gettext 'Resuming $APP_LONG_NAME.'`
+}
+
+status() {
+ getpid
+ if [ "X$pid" = "X" ]
+ then
+ eval echo `gettext '$APP_LONG_NAME is not running.'`
+ exit 1
+ else
+ if [ "X$DETAIL_STATUS" = "X" ]
+ then
+ eval echo `gettext '$APP_LONG_NAME is running: PID:$pid'`
+ else
+ getstatus
+ eval echo `gettext '$APP_LONG_NAME is running: PID:$pid, Wrapper:$STATUS, Java:$JAVASTATUS'`
+ fi
+ exit 0
+ fi
+}
+
+# Make sure APP_NAME is less than 14 characters, otherwise in AIX, the command
+# "lsitab" will fail
+validateAppNameLength() {
+ if [ ${#APP_NAME} -gt 14 ] ; then
+ eval echo `gettext ' APP_NAME (${APP_NAME}) must be less than 14 characters long'`
+ exit 1
+ fi
+}
+
+installUpstart() {
+ eval echo `gettext ' Installing the $APP_LONG_NAME daemon using upstart..'`
+ if [ -f "${REALDIR}/${APP_NAME}.install" ] ; then
+ eval echo `gettext ' a custom upstart conf file ${APP_NAME}.install found'`
+ cp "${REALDIR}/${APP_NAME}.install" "/etc/init/${APP_NAME}.conf"
+ else
+ eval echo `gettext ' creating default upstart conf file..'`
+ echo "# ${APP_NAME} - ${APP_LONG_NAME}" > "/etc/init/${APP_NAME}.conf"
+ echo "description \"${APP_LONG_NAME}\"" >> "/etc/init/${APP_NAME}.conf"
+ echo "author \"Tanuki Software Ltd. \"" >> "/etc/init/${APP_NAME}.conf"
+ echo "start on runlevel [2345]" >> "/etc/init/${APP_NAME}.conf"
+ echo "stop on runlevel [!2345]" >> "/etc/init/${APP_NAME}.conf"
+ echo "env LANG=${LANG}" >> "/etc/init/${APP_NAME}.conf"
+ echo "exec \"${REALPATH}\" upstartinternal" >> "/etc/init/${APP_NAME}.conf"
+ fi
+}
+
+installdaemon() {
+ mustBeRootOrExit
+
+ APP_NAME_LOWER=`echo "$APP_NAME" | $TR_BIN "[A-Z]" "[a-z]"`
+ if [ "$DIST_OS" = "solaris" ] ; then
+ eval echo `gettext 'Detected Solaris:'`
+ if [ -f "/etc/init.d/$APP_NAME" -o -L "/etc/init.d/$APP_NAME" ] ; then
+ eval echo `gettext ' The $APP_LONG_NAME daemon is already installed.'`
+ if [ "$COMMAND" != 'installstart' ] ; then
+ exit 1
+ fi
+ else
+ eval echo `gettext ' Installing the $APP_LONG_NAME daemon..'`
+ ln -s "$REALPATH" "/etc/init.d/$APP_NAME"
+ for i in `ls "/etc/rc3.d/K"??"$APP_NAME_LOWER" "/etc/rc3.d/S"??"$APP_NAME_LOWER" 2>/dev/null` ; do
+ eval echo `gettext ' Removing unexpected file before proceeding: $i'`
+ rm -f $i
+ done
+ ln -s "/etc/init.d/$APP_NAME" "/etc/rc3.d/K${APP_RUN_LEVEL_K}$APP_NAME_LOWER"
+ ln -s "/etc/init.d/$APP_NAME" "/etc/rc3.d/S${APP_RUN_LEVEL_S}$APP_NAME_LOWER"
+ fi
+ elif [ "$DIST_OS" = "linux" ] ; then
+ if [ -f /etc/redhat-release -o -f /etc/redhat_version -o -f /etc/fedora-release ] ; then
+ eval echo `gettext 'Detected RHEL or Fedora:'`
+ if [ -f "/etc/init.d/$APP_NAME" -o -L "/etc/init.d/$APP_NAME" -o -f "/etc/init/${APP_NAME}.conf" ] ; then
+ eval echo `gettext ' The $APP_LONG_NAME daemon is already installed.'`
+ if [ "$COMMAND" != 'installstart' ] ; then
+ exit 1
+ fi
+ elif [ -n "$USE_SYSTEMD" -a -d "/etc/systemd" ] ; then
+ systemdInstall
+ else
+ if [ -n "$USE_UPSTART" -a -d "/etc/init" ] ; then
+ installUpstart
+ else
+ eval echo `gettext ' Installing the $APP_LONG_NAME daemon..'`
+ ln -s "$REALPATH" "/etc/init.d/$APP_NAME"
+ /sbin/chkconfig --add "$APP_NAME"
+ /sbin/chkconfig "$APP_NAME" on
+ fi
+ fi
+ elif [ -f /etc/SuSE-release ] ; then
+ eval echo `gettext 'Detected SuSE or SLES:'`
+ if [ -f "/etc/init.d/$APP_NAME" -o -L "/etc/init.d/$APP_NAME" ] ; then
+ eval echo `gettext ' The $APP_LONG_NAME daemon is already installed.'`
+ if [ "$COMMAND" != 'installstart' ] ; then
+ exit 1
+ fi
+ elif [ -n "$USE_SYSTEMD" -a -d "/etc/systemd" ] ; then
+ systemdInstall
+ else
+ eval echo `gettext ' Installing the $APP_LONG_NAME daemon..'`
+ ln -s "$REALPATH" "/etc/init.d/$APP_NAME"
+ insserv "/etc/init.d/$APP_NAME"
+ fi
+ elif [ -f /etc/lsb-release -o -f /etc/debian_version -o -f /etc/debian_release ] ; then
+ eval echo `gettext 'Detected Ubuntu or Debian:'`
+ if [ -f "/etc/init.d/$APP_NAME" -o -L "/etc/init.d/$APP_NAME" -o -f "/etc/init/${APP_NAME}.conf" ] ; then
+ eval echo `gettext ' The $APP_LONG_NAME daemon is already installed.'`
+ if [ "$COMMAND" != 'installstart' ] ; then
+ exit 1
+ fi
+ else
+ if [ -n "$USE_SYSTEMD" -a -d "/etc/systemd" ] ; then
+ systemdInstall
+ elif [ -n "$USE_UPSTART" -a -d "/etc/init" ] ; then
+ installUpstart
+ else
+ eval echo `gettext ' Installing the $APP_LONG_NAME daemon using init.d..'`
+ ln -s "$REALPATH" "/etc/init.d/$APP_NAME"
+ update-rc.d "$APP_NAME" defaults
+ fi
+ fi
+ else
+ eval echo `gettext 'Detected Linux:'`
+ if [ -f "/etc/init.d/$APP_NAME" -o -L "/etc/init.d/$APP_NAME" ] ; then
+ eval echo `gettext ' The $APP_LONG_NAME daemon is already installed.'`
+ if [ "$COMMAND" != 'installstart' ] ; then
+ exit 1
+ fi
+ else
+ eval echo `gettext ' Installing the $APP_LONG_NAME daemon..'`
+ ln -s "$REALPATH" /etc/init.d/$APP_NAME
+ for i in `ls "/etc/rc3.d/K"??"$APP_NAME_LOWER" "/etc/rc5.d/K"??"$APP_NAME_LOWER" "/etc/rc3.d/S"??"$APP_NAME_LOWER" "/etc/rc5.d/S"??"$APP_NAME_LOWER" 2>/dev/null` ; do
+ eval echo `gettext ' Removing unexpected file before proceeding: $i'`
+ rm -f $i
+ done
+ ln -s "/etc/init.d/$APP_NAME" "/etc/rc3.d/K${APP_RUN_LEVEL_K}$APP_NAME_LOWER"
+ ln -s "/etc/init.d/$APP_NAME" "/etc/rc3.d/S${APP_RUN_LEVEL_S}$APP_NAME_LOWER"
+ ln -s "/etc/init.d/$APP_NAME" "/etc/rc5.d/S${APP_RUN_LEVEL_S}$APP_NAME_LOWER"
+ ln -s "/etc/init.d/$APP_NAME" "/etc/rc5.d/K${APP_RUN_LEVEL_K}$APP_NAME_LOWER"
+ fi
+ fi
+ elif [ "$DIST_OS" = "hpux" ] ; then
+ eval echo `gettext 'Detected HP-UX:'`
+ if [ -f "/sbin/init.d/$APP_NAME" -o -L "/sbin/init.d/$APP_NAME" ] ; then
+ eval echo `gettext ' The $APP_LONG_NAME daemon is already installed.'`
+ if [ "$COMMAND" != 'installstart' ] ; then
+ exit 1
+ fi
+ else
+ eval echo `gettext ' Installing the $APP_LONG_NAME daemon..'`
+ ln -s "$REALPATH" "/sbin/init.d/$APP_NAME"
+ for i in `ls "/sbin/rc3.d/K"??"$APP_NAME_LOWER" "/sbin/rc3.d/S"??"$APP_NAME_LOWER" 2>/dev/null` ; do
+ eval echo `gettext ' Removing unexpected file before proceeding: $i'`
+ rm -f $i
+ done
+ ln -s "/sbin/init.d/$APP_NAME" "/sbin/rc3.d/K${APP_RUN_LEVEL_K}$APP_NAME_LOWER"
+ ln -s "/sbin/init.d/$APP_NAME" "/sbin/rc3.d/S${APP_RUN_LEVEL_S}$APP_NAME_LOWER"
+ fi
+ elif [ "$DIST_OS" = "aix" ] ; then
+ eval echo `gettext 'Detected AIX:'`
+ validateAppNameLength
+ if [ -f "/etc/rc.d/init.d/$APP_NAME" ] ; then
+ eval echo `gettext ' The $APP_LONG_NAME daemon is already installed as rc.d script.'`
+ if [ "$COMMAND" != 'installstart' ] ; then
+ exit 1
+ fi
+ elif [ -n "`/usr/sbin/lsitab $APP_NAME`" -a -n "`/usr/bin/lssrc -S -s $APP_NAME`" ] ; then
+ eval echo `gettext ' The $APP_LONG_NAME daemon is already installed as SRC service.'`
+ if [ "$COMMAND" != 'installstart' ] ; then
+ exit 1
+ fi
+ else
+ eval echo `gettext ' Installing the $APP_LONG_NAME daemon..'`
+ if [ -n "`/usr/sbin/lsitab install_assist`" ] ; then
+ eval echo `gettext ' The task /usr/sbin/install_assist was found in the inittab, this might cause problems for all subsequent tasks to launch at this process is known to block the init task. Please make sure this task is not needed anymore and remove/deactivate it.'`
+ fi
+ for i in `ls "/etc/rc.d/rc2.d/K"??"$APP_NAME_LOWER" "/etc/rc.d/rc2.d/S"??"$APP_NAME_LOWER" 2>/dev/null` ; do
+ eval echo `gettext ' Removing unexpected file before proceeding: $i'`
+ rm -f $i
+ done
+ srcInstall
+ fi
+ elif [ "$DIST_OS" = "freebsd" ] ; then
+ eval echo `gettext 'Detected FreeBSD:'`
+ if [ -f "/etc/rc.d/$APP_NAME" -o -L "/etc/rc.d/$APP_NAME" ] ; then
+ eval echo `gettext ' The $APP_LONG_NAME daemon is already installed.'`
+ if [ "$COMMAND" != 'installstart' ] ; then
+ exit 1
+ fi
+ else
+ eval echo `gettext ' Installing the $APP_LONG_NAME daemon..'`
+ sed -i .bak "/${APP_NAME}_enable=\"YES\"/d" /etc/rc.conf
+ if [ -f "${REALDIR}/${APP_NAME}.install" ] ; then
+ ln -s "${REALDIR}/${APP_NAME}.install" "/etc/rc.d/$APP_NAME"
+ else
+ echo '#!/bin/sh' > "/etc/rc.d/$APP_NAME"
+ echo "#" >> "/etc/rc.d/$APP_NAME"
+ echo "# PROVIDE: $APP_NAME" >> "/etc/rc.d/$APP_NAME"
+ echo "# REQUIRE: NETWORKING" >> "/etc/rc.d/$APP_NAME"
+ echo "# KEYWORD: shutdown" >> "/etc/rc.d/$APP_NAME"
+ echo ". /etc/rc.subr" >> "/etc/rc.d/$APP_NAME"
+ echo "name=\"$APP_NAME\"" >> "/etc/rc.d/$APP_NAME"
+ echo "rcvar=\`set_rcvar\`" >> "/etc/rc.d/$APP_NAME"
+ echo "command=\"${REALPATH}\"" >> "/etc/rc.d/$APP_NAME"
+ echo 'start_cmd="${name}_start"' >> "/etc/rc.d/$APP_NAME"
+ echo 'load_rc_config $name' >> "/etc/rc.d/$APP_NAME"
+ echo 'status_cmd="${name}_status"' >> "/etc/rc.d/$APP_NAME"
+ echo 'stop_cmd="${name}_stop"' >> "/etc/rc.d/$APP_NAME"
+ echo "${APP_NAME}_status() {" >> "/etc/rc.d/$APP_NAME"
+ echo '${command} status' >> "/etc/rc.d/$APP_NAME"
+ echo '}' >> "/etc/rc.d/$APP_NAME"
+ echo "${APP_NAME}_stop() {" >> "/etc/rc.d/$APP_NAME"
+ echo '${command} stop' >> "/etc/rc.d/$APP_NAME"
+ echo '}' >> "/etc/rc.d/$APP_NAME"
+ echo "${APP_NAME}_start() {" >> "/etc/rc.d/$APP_NAME"
+ echo '${command} start' >> "/etc/rc.d/$APP_NAME"
+ echo '}' >> "/etc/rc.d/$APP_NAME"
+ echo 'run_rc_command "$1"' >> "/etc/rc.d/$APP_NAME"
+ fi
+ echo "${APP_NAME}_enable=\"YES\"" >> /etc/rc.conf
+ chmod 555 "/etc/rc.d/$APP_NAME"
+ fi
+ elif [ "$DIST_OS" = "macosx" ] ; then
+ eval echo `gettext 'Detected Mac OSX:'`
+ if [ -f "/Library/LaunchDaemons/${APP_PLIST}" -o -L "/Library/LaunchDaemons/${APP_PLIST}" ] ; then
+ eval echo `gettext ' The $APP_LONG_NAME daemon is already installed.'`
+ if [ "$COMMAND" != 'installstart' ] ; then
+ exit 1
+ fi
+ else
+ eval echo `gettext ' Installing the $APP_LONG_NAME daemon..'`
+ if [ -f "${REALDIR}/${APP_PLIST}" ] ; then
+ ln -s "${REALDIR}/${APP_PLIST}" "/Library/LaunchDaemons/${APP_PLIST}"
+ else
+ echo "" > "/Library/LaunchDaemons/${APP_PLIST}"
+ echo "> "/Library/LaunchDaemons/${APP_PLIST}"
+ echo "\"http://www.apple.com/DTDs/PropertyList-1.0.dtd\">" >> "/Library/LaunchDaemons/${APP_PLIST}"
+ echo "" >> "/Library/LaunchDaemons/${APP_PLIST}"
+ echo " " >> "/Library/LaunchDaemons/${APP_PLIST}"
+ echo " Label" >> "/Library/LaunchDaemons/${APP_PLIST}"
+ echo " ${APP_PLIST_BASE}" >> "/Library/LaunchDaemons/${APP_PLIST}"
+ echo " ProgramArguments" >> "/Library/LaunchDaemons/${APP_PLIST}"
+ echo " " >> "/Library/LaunchDaemons/${APP_PLIST}"
+ echo " ${REALPATH}" >> "/Library/LaunchDaemons/${APP_PLIST}"
+ echo " launchdinternal" >> "/Library/LaunchDaemons/${APP_PLIST}"
+ echo " " >> "/Library/LaunchDaemons/${APP_PLIST}"
+ echo " ${KEY_KEEP_ALIVE}" >> "/Library/LaunchDaemons/${APP_PLIST}"
+ echo " <${MACOSX_KEEP_RUNNING}/>" >> "/Library/LaunchDaemons/${APP_PLIST}"
+ echo " RunAtLoad" >> "/Library/LaunchDaemons/${APP_PLIST}"
+ echo " " >> "/Library/LaunchDaemons/${APP_PLIST}"
+ if [ "X$RUN_AS_USER" != "X" ] ; then
+ echo " UserName" >> "/Library/LaunchDaemons/${APP_PLIST}"
+ echo " ${RUN_AS_USER}" >> "/Library/LaunchDaemons/${APP_PLIST}"
+ fi
+ echo " " >> "/Library/LaunchDaemons/${APP_PLIST}"
+ echo "" >> "/Library/LaunchDaemons/${APP_PLIST}"
+ fi
+ chmod 555 "/Library/LaunchDaemons/${APP_PLIST}"
+ fi
+ elif [ "$DIST_OS" = "zos" ] ; then
+ eval echo `gettext 'Detected z/OS:'`
+ if [ -f /etc/rc.bak ] ; then
+ eval echo `gettext ' The $APP_LONG_NAME daemon is already installed.'`
+ if [ "$COMMAND" != 'installstart' ] ; then
+ exit 1
+ fi
+ else
+ eval echo `gettext ' Installing the $APP_LONG_NAME daemon..'`
+ cp /etc/rc /etc/rc.bak
+ sed "s:echo /etc/rc script executed, \`date\`::g" /etc/rc.bak > /etc/rc
+ echo "_BPX_JOBNAME='${APP_NAME}' \"${REALDIR}/${APP_NAME}\" start" >>/etc/rc
+ echo '/etc/rc script executed, `date`' >>/etc/rc
+ fi
+ else
+ eval echo `gettext 'Install not currently supported for $DIST_OS'`
+ exit 1
+ fi
+}
+
+startdaemon() {
+ if [ "$DIST_OS" = "macosx" ] ; then
+ if [ ! -f "/Library/LaunchDaemons/${APP_PLIST}" ] ; then
+ eval echo `gettext 'The $APP_LONG_NAME daemon is not currently installed.'`
+ else
+ macosxStart
+ fi
+ elif [ "$DIST_OS" = "linux" -a -f "/etc/init/${APP_NAME}.conf" ] ; then
+ upstartstart
+ elif [ "$DIST_OS" = "linux" -a -n "$USE_SYSTEMD" -a -z "$SYSD" ] ; then
+ systemdStart
+ elif [ "$DIST_OS" = "aix" ] && [ -n "`/usr/bin/lssrc -S -s $APP_NAME`" ] ; then
+ srcStart
+ else
+ if [ -n "$SYSD" ] ; then
+ shift
+ fi
+
+ checkUser touchlock "$@"
+ if [ ! -n "$FIXED_COMMAND" ] ; then
+ shift
+ fi
+ start "$@"
+ fi
+}
+
+removedaemon() {
+ mustBeRootOrExit
+
+ APP_NAME_LOWER=`echo "$APP_NAME" | $TR_BIN "[A-Z]" "[a-z]"`
+ if [ "$DIST_OS" = "solaris" ] ; then
+ eval echo `gettext 'Detected Solaris:'`
+ if [ -f "/etc/init.d/$APP_NAME" -o -L "/etc/init.d/$APP_NAME" ] ; then
+ stopit "0"
+ eval echo `gettext ' Removing $APP_LONG_NAME daemon...'`
+ for i in `ls "/etc/rc3.d/K"??"$APP_NAME_LOWER" "/etc/rc3.d/S"??"$APP_NAME_LOWER" "/etc/init.d/$APP_NAME" 2>/dev/null` ; do
+ rm -f $i
+ done
+ else
+ eval echo `gettext ' The $APP_LONG_NAME daemon is not currently installed.'`
+ exit 1
+ fi
+ elif [ "$DIST_OS" = "linux" ] ; then
+ if [ -f /etc/redhat-release -o -f /etc/redhat_version -o -f /etc/fedora-release ] ; then
+ eval echo `gettext 'Detected RHEL or Fedora:'`
+ if [ -f "/etc/init.d/$APP_NAME" -o -L "/etc/init.d/$APP_NAME" ] ; then
+ stopit "0"
+ eval echo `gettext ' Removing $APP_LONG_NAME daemon...'`
+ /sbin/chkconfig "$APP_NAME" off
+ /sbin/chkconfig --del "$APP_NAME"
+ rm -f "/etc/init.d/$APP_NAME"
+ elif [ -n "$USE_SYSTEMD" -a -f "${SYSTEMD_SERVICE_FILE}" ] ; then
+ systemdRemove
+ elif [ -f "/etc/init/${APP_NAME}.conf" ] ; then
+ stopit "0"
+ eval echo `gettext ' Removing $APP_LONG_NAME daemon from upstart...'`
+ rm "/etc/init/${APP_NAME}.conf"
+ else
+ eval echo `gettext ' The $APP_LONG_NAME daemon is not currently installed.'`
+ exit 1
+ fi
+ elif [ -f /etc/SuSE-release ] ; then
+ eval echo `gettext 'Detected SuSE or SLES:'`
+ if [ -f "/etc/init.d/$APP_NAME" -o -L "/etc/init.d/$APP_NAME" ] ; then
+ stopit "0"
+ eval echo `gettext ' Removing $APP_LONG_NAME daemon...'`
+ insserv -r "/etc/init.d/$APP_NAME"
+ rm -f "/etc/init.d/$APP_NAME"
+ elif [ -n "$USE_SYSTEMD" -a -f "${SYSTEMD_SERVICE_FILE}" ] ; then
+ systemdRemove
+ else
+ eval echo `gettext ' The $APP_LONG_NAME daemon is not currently installed.'`
+ exit 1
+ fi
+ elif [ -f /etc/lsb-release -o -f /etc/debian_version -o -f /etc/debian_release ] ; then
+ eval echo `gettext 'Detected Ubuntu or Debian:'`
+ if [ -f "/etc/init.d/$APP_NAME" -o -L "/etc/init.d/$APP_NAME" ] ; then
+ stopit "0"
+ eval echo `gettext ' Removing $APP_LONG_NAME daemon from init.d...'`
+ update-rc.d -f "$APP_NAME" remove
+ rm -f "/etc/init.d/$APP_NAME"
+ elif [ -n "$USE_SYSTEMD" -a -f "${SYSTEMD_SERVICE_FILE}" ] ; then
+ systemdRemove
+ elif [ -f "/etc/init/${APP_NAME}.conf" ] ; then
+ stopit "0"
+ eval echo `gettext ' Removing $APP_LONG_NAME daemon from upstart...'`
+ rm "/etc/init/${APP_NAME}.conf"
+ else
+ eval echo `gettext ' The $APP_LONG_NAME daemon is not currently installed.'`
+ exit 1
+ fi
+ else
+ eval echo `gettext 'Detected Linux:'`
+ if [ -f "/etc/init.d/$APP_NAME" -o -L "/etc/init.d/$APP_NAME" ] ; then
+ stopit "0"
+ eval echo `gettext ' Removing $APP_LONG_NAME daemon...'`
+ for i in `ls "/etc/rc3.d/K"??"$APP_NAME_LOWER" "/etc/rc5.d/K"??"$APP_NAME_LOWER" "/etc/rc3.d/S"??"$APP_NAME_LOWER" "/etc/rc5.d/S"??"$APP_NAME_LOWER" "/etc/init.d/$APP_NAME" 2>/dev/null` ; do
+ rm -f $i
+ done
+ else
+ eval echo `gettext ' The $APP_LONG_NAME daemon is not currently installed.'`
+ exit 1
+ fi
+ fi
+ elif [ "$DIST_OS" = "hpux" ] ; then
+ eval echo `gettext 'Detected HP-UX:'`
+ if [ -f "/sbin/init.d/$APP_NAME" -o -L "/sbin/init.d/$APP_NAME" ] ; then
+ stopit "0"
+ eval echo `gettext ' Removing $APP_LONG_NAME daemon...'`
+ for i in `ls "/sbin/rc3.d/K"??"$APP_NAME_LOWER" "/sbin/rc3.d/S"??"$APP_NAME_LOWER" "/sbin/init.d/$APP_NAME" 2>/dev/null` ; do
+ rm -f $i
+ done
+ else
+ eval echo `gettext ' The $APP_LONG_NAME daemon is not currently installed.'`
+ exit 1
+ fi
+ elif [ "$DIST_OS" = "aix" ] ; then
+ eval echo `gettext 'Detected AIX:'`
+ validateAppNameLength
+ if [ -f "/etc/rc.d/init.d/$APP_NAME" -o -L "/etc/rc.d/init.d/$APP_NAME" -o -n "`/usr/sbin/lsitab $APP_NAME`" -o -n "`/usr/bin/lssrc -S -s $APP_NAME`" ] ; then
+ stopit "0"
+ eval echo `gettext ' Removing $APP_LONG_NAME daemon...'`
+ if [ -f "/etc/rc.d/init.d/$APP_NAME" -o -L "/etc/rc.d/init.d/$APP_NAME" ] ; then
+ for i in `ls "/etc/rc.d/rc2.d/K"??"$APP_NAME_LOWER" "/etc/rc.d/rc2.d/S"??"$APP_NAME_LOWER" "/etc/rc.d/init.d/$APP_NAME" 2>/dev/null` ; do
+ rm -f $i
+ done
+ fi
+ if [ -n "`/usr/sbin/lsitab $APP_NAME`" -o -n "`/usr/bin/lssrc -S -s $APP_NAME`" ] ; then
+ /usr/sbin/rmitab $APP_NAME
+ /usr/bin/rmssys -s $APP_NAME
+ fi
+ else
+ eval echo `gettext ' The $APP_LONG_NAME daemon is not currently installed.'`
+ exit 1
+ fi
+ elif [ "$DIST_OS" = "freebsd" ] ; then
+ eval echo `gettext 'Detected FreeBSD:'`
+ if [ -f "/etc/rc.d/$APP_NAME" -o -L "/etc/rc.d/$APP_NAME" ] ; then
+ stopit "0"
+ eval echo `gettext ' Removing $APP_LONG_NAME daemon...'`
+ for i in "/etc/rc.d/$APP_NAME"
+ do
+ rm -f $i
+ done
+ sed -i .bak "/${APP_NAME}_enable=\"YES\"/d" /etc/rc.conf
+ else
+ eval echo `gettext ' The $APP_LONG_NAME daemon is not currently installed.'`
+ exit 1
+ fi
+ elif [ "$DIST_OS" = "macosx" ] ; then
+ eval echo `gettext 'Detected Mac OSX:'`
+ if [ -f "/Library/LaunchDaemons/${APP_PLIST}" -o -L "/Library/LaunchDaemons/${APP_PLIST}" ] ; then
+ stopit "0"
+ eval echo `gettext ' Removing $APP_LONG_NAME daemon...'`
+ # Make sure the plist is installed
+ LOADED_PLIST=`launchctl list | grep ${APP_PLIST_BASE}`
+ if [ "X${LOADED_PLIST}" != "X" ] ; then
+ launchctl unload "/Library/LaunchDaemons/${APP_PLIST}"
+ fi
+ rm -f "/Library/LaunchDaemons/${APP_PLIST}"
+ else
+ eval echo `gettext ' The $APP_LONG_NAME daemon is not currently installed.'`
+ exit 1
+ fi
+ elif [ "$DIST_OS" = "zos" ] ; then
+ eval echo `gettext 'Detected z/OS:'`
+ if [ -f /etc/rc.bak ] ; then
+ stopit "0"
+ eval echo `gettext ' Removing $APP_LONG_NAME daemon...'`
+ cp /etc/rc /etc/rc.bak
+ sed "s/_BPX_JOBNAME=\'APP_NAME\'.*//g" /etc/rc.bak > /etc/rc
+ rm /etc/rc.bak
+ else
+ eval echo `gettext ' The $APP_LONG_NAME daemon is not currently installed.'`
+ exit 1
+ fi
+ else
+ eval echo `gettext 'Remove not currently supported for $DIST_OS'`
+ exit 1
+ fi
+}
+
+dump() {
+ eval echo `gettext 'Dumping $APP_LONG_NAME...'`
+ getpid
+ if [ "X$pid" = "X" ]
+ then
+ eval echo `gettext '$APP_LONG_NAME was not running.'`
+ else
+ kill -3 $pid
+
+ if [ $? -ne 0 ]
+ then
+ eval echo `gettext 'Failed to dump $APP_LONG_NAME.'`
+ exit 1
+ else
+ eval echo `gettext 'Dumped $APP_LONG_NAME.'`
+ fi
+ fi
+}
+
+# Used by HP-UX init scripts.
+startmsg() {
+ getpid
+ if [ "X$pid" = "X" ]
+ then
+ eval echo `gettext 'Starting $APP_LONG_NAME... Wrapper:Stopped'`
+ else
+ if [ "X$DETAIL_STATUS" = "X" ]
+ then
+ eval echo `gettext 'Starting $APP_LONG_NAME... Wrapper:Running'`
+ else
+ getstatus
+ eval echo `gettext 'Starting $APP_LONG_NAME... Wrapper:$STATUS, Java:$JAVASTATUS'`
+ fi
+ fi
+}
+
+# Used by HP-UX init scripts.
+stopmsg() {
+ getpid
+ if [ "X$pid" = "X" ]
+ then
+ eval echo `gettext 'Stopping $APP_LONG_NAME... Wrapper:Stopped'`
+ else
+ if [ "X$DETAIL_STATUS" = "X" ]
+ then
+ eval echo `gettext 'Stopping $APP_LONG_NAME... Wrapper:Running'`
+ else
+ getstatus
+ eval echo `gettext 'Stopping $APP_LONG_NAME... Wrapper:$STATUS, Java:$JAVASTATUS'`
+ fi
+ fi
+}
+
+showUsage() {
+ # $1 bad command
+
+ if [ -n "$1" ]
+ then
+ eval echo `gettext 'Unexpected command: $1'`
+ echo "";
+ fi
+
+ eval MSG=`gettext 'Usage: '`
+ if [ -n "$FIXED_COMMAND" ] ; then
+ if [ -n "$PASS_THROUGH" ] ; then
+ echo "${MSG} $0 {JavaAppArgs}"
+ else
+ echo "${MSG} $0"
+ fi
+ else
+ if [ -n "$PAUSABLE" ] ; then
+ if [ -n "$PASS_THROUGH" ] ; then
+ echo "${MSG} $0 [ console {JavaAppArgs} | start {JavaAppArgs} | stop | restart {JavaAppArgs} | condrestart {JavaAppArgs} | pause | resume | status | install | installstart | remove | dump ]"
+ else
+ echo "${MSG} $0 [ console | start | stop | restart | condrestart | pause | resume | status | install | installstart | remove | dump ]"
+ fi
+ else
+ if [ -n "$PASS_THROUGH" ] ; then
+ echo "${MSG} $0 [ console {JavaAppArgs} | start {JavaAppArgs} | stop | restart {JavaAppArgs} | condrestart {JavaAppArgs} | status | install | installstart | remove | dump ]"
+ else
+ echo "${MSG} $0 [ console | start | stop | restart | condrestart | status | install | installstart | remove | dump ]"
+ fi
+ fi
+ fi
+
+ if [ ! -n "$BRIEF_USAGE" ]
+ then
+ echo "";
+ if [ ! -n "$FIXED_COMMAND" ] ; then
+ echo "`gettext 'Commands:'`"
+ echo "`gettext ' console Launch in the current console.'`"
+ echo "`gettext ' start Start in the background as a daemon process.'`"
+ echo "`gettext ' stop Stop if running as a daemon or in another console.'`"
+ echo "`gettext ' restart Stop if running and then start.'`"
+ echo "`gettext ' condrestart Restart only if already running.'`"
+ if [ -n "$PAUSABLE" ] ; then
+ echo "`gettext ' pause Pause if running.'`"
+ echo "`gettext ' resume Resume if paused.'`"
+ fi
+ echo "`gettext ' status Query the current status.'`"
+ echo "`gettext ' install Install to start automatically when system boots.'`"
+ echo "`gettext ' installstart Install and start running as a daemon process.'`"
+ echo "`gettext ' remove Uninstall.'`"
+ echo "`gettext ' dump Request a Java thread dump if running.'`"
+ echo "";
+ fi
+ if [ -n "$PASS_THROUGH" ] ; then
+ echo "`gettext 'JavaAppArgs: Zero or more arguments which will be passed to the Java application.'`"
+ echo "";
+ fi
+ fi
+
+ exit 1
+}
+
+docommand() {
+ case "$COMMAND" in
+ 'console')
+ checkUser touchlock "$@"
+ if [ ! -n "$FIXED_COMMAND" ] ; then
+ shift
+ fi
+ console "$@"
+ ;;
+
+ 'start')
+ startdaemon "$@"
+ ;;
+
+ 'stop')
+ if [ "$DIST_OS" = "macosx" -a -f "/Library/LaunchDaemons/${APP_PLIST}" ] ; then
+ macosxStop
+ elif [ "$DIST_OS" = "linux" -a -f "/etc/init/${APP_NAME}.conf" ] ; then
+ upstartStop
+ elif [ "$DIST_OS" = "linux" -a -n "$USE_SYSTEMD" -a -z "$SYSD" ] ; then
+ systemdStop
+ elif [ "$DIST_OS" = "aix" ] && [ "`/usr/bin/lssrc -S -s $APP_NAME`" ] ; then
+ srcStop
+ else
+ checkUser "" "$COMMAND"
+ stopit "0"
+ fi
+ ;;
+
+ 'restart')
+ if [ "$DIST_OS" = "macosx" ] ; then
+ if [ ! -f "/Library/LaunchDaemons/${APP_PLIST}" ] ; then
+ eval echo `gettext '$APP_NAME was not installed.'`
+ else
+ macosxRestart
+ fi
+ elif [ "$DIST_OS" = "linux" -a -f "/etc/init/${APP_NAME}.conf" ] ; then
+ upstartRestart
+ elif [ "$DIST_OS" = "linux" -a -n "$USE_SYSTEMD" -a -z "$SYSD" ] ; then
+ systemdRestart
+ elif [ "$DIST_OS" = "aix" ] && [ "`/usr/bin/lssrc -S -s $APP_NAME`" ] ; then
+ srcRestart
+ else
+ if [ -n "$SMF" ] ; then
+ shift
+ fi
+ checkUser touchlock "$COMMAND"
+ if [ ! -n "$FIXED_COMMAND" ] ; then
+ shift
+ fi
+ stopit "0"
+ start "$@"
+ fi
+ ;;
+
+ 'condrestart')
+ checkUser touchlock "$COMMAND"
+ if [ ! -n "$FIXED_COMMAND" ] ; then
+ shift
+ fi
+ stopit "1"
+ start "$@"
+ ;;
+
+ 'pause')
+ if [ -n "$PAUSABLE" ]
+ then
+ pause
+ else
+ showUsage "$COMMAND"
+ fi
+ ;;
+
+ 'resume')
+ if [ -n "$PAUSABLE" ]
+ then
+ resume
+ else
+ showUsage "$COMMAND"
+ fi
+ ;;
+
+ 'status')
+ status
+ ;;
+
+ 'install')
+ installdaemon "$@"
+ ;;
+
+ 'installstart')
+ installdaemon "$@"
+ startdaemon "$@"
+ ;;
+
+ 'remove')
+ removedaemon
+ ;;
+
+ 'dump')
+ checkUser "" "$COMMAND"
+ dump
+ ;;
+
+ 'start_msg')
+ # Internal command called by launchd on HP-UX.
+ checkUser "" "$COMMAND"
+ startmsg
+ ;;
+
+ 'stop_msg')
+ # Internal command called by launchd on HP-UX.
+ checkUser "" "$COMMAND"
+ stopmsg
+ ;;
+
+ 'launchdinternal' | 'upstartinternal')
+ if [ ! "$DIST_OS" = "macosx" -o ! -f "/Library/LaunchDaemons/${APP_PLIST}" ] ; then
+ checkUser touchlock "$@"
+ fi
+ # Internal command called by launchd on Max OSX.
+ # We do not want to call checkUser here as it is handled in the launchd plist file. Doing it here would confuse launchd.
+ if [ ! -n "$FIXED_COMMAND" ] ; then
+ shift
+ fi
+ launchinternal "$@"
+ ;;
+
+ *)
+ showUsage "$COMMAND"
+ ;;
+ esac
+}
+
+docommand "$@"
+
+exit 0
diff --git a/food-open/food-open-api/src/main/bin/pause.bat b/food-open/food-open-api/src/main/bin/pause.bat
new file mode 100644
index 0000000..65a2166
--- /dev/null
+++ b/food-open/food-open-api/src/main/bin/pause.bat
@@ -0,0 +1,135 @@
+@echo off
+setlocal
+
+rem
+rem Copyright (c) 1999, 2016 Tanuki Software, Ltd.
+rem http://www.tanukisoftware.com
+rem All rights reserved.
+rem
+rem This software is the proprietary information of Tanuki Software.
+rem You shall use it only in accordance with the terms of the
+rem license agreement you entered into with Tanuki Software.
+rem http://wrapper.tanukisoftware.com/doc/english/licenseOverview.html
+rem
+rem Java Service Wrapper general startup script.
+rem
+
+rem -----------------------------------------------------------------------------
+rem These settings can be modified to fit the needs of your application
+rem Optimized for use with version 3.5.28 of the Wrapper.
+
+rem The base name for the Wrapper binary.
+set _WRAPPER_BASE=wrapper
+
+rem The directory where the Wrapper binary (.exe) file is located. It can be
+rem either an absolute or a relative path. If the path contains any special
+rem characters, please make sure to quote the variable.
+set _WRAPPER_DIR=
+
+rem The name and location of the Wrapper configuration file. This will be used
+rem if the user does not specify a configuration file as the first parameter to
+rem this script.
+set _WRAPPER_CONF_DEFAULT="../conf/%_WRAPPER_BASE%.conf"
+
+rem Makes it possible to override the Wrapper configuration file by specifying it
+rem as the first parameter.
+rem set _WRAPPER_CONF_OVERRIDE=true
+
+rem Note that it is only possible to pass parameters through to the JVM when
+rem installing the service, or when running in a console.
+
+rem Do not modify anything beyond this point
+rem -----------------------------------------------------------------------------
+
+rem
+rem Resolve the real path of the wrapper.exe
+rem For non NT systems, the _REALPATH and _WRAPPER_CONF values
+rem can be hard-coded below and the following test removed.
+rem
+if "%OS%"=="Windows_NT" goto nt
+echo This script only works with NT-based versions of Windows.
+goto :eof
+
+:nt
+rem Find the application home.
+rem if no path path specified do the default action
+IF not DEFINED _WRAPPER_DIR goto dir_undefined
+set _WRAPPER_DIR_QUOTED="%_WRAPPER_DIR:"=%"
+if not "%_WRAPPER_DIR:~-2,1%" == "\" set _WRAPPER_DIR_QUOTED="%_WRAPPER_DIR_QUOTED:"=%\"
+rem check if absolute path
+if "%_WRAPPER_DIR_QUOTED:~2,1%" == ":" goto absolute_path
+if "%_WRAPPER_DIR_QUOTED:~1,1%" == "\" goto absolute_path
+rem everythig else means relative path
+set _REALPATH="%~dp0%_WRAPPER_DIR_QUOTED:"=%"
+goto pathfound
+
+:dir_undefined
+rem Use a relative path to the wrapper %~dp0 is location of current script under NT
+set _REALPATH="%~dp0"
+goto pathfound
+:absolute_path
+rem Use an absolute path to the wrapper
+set _REALPATH="%_WRAPPER_DIR_QUOTED:"=%"
+
+:pathfound
+rem
+rem Decide on the specific Wrapper binary to use (See delta-pack)
+rem
+if "%PROCESSOR_ARCHITEW6432%"=="AMD64" goto amd64
+if "%PROCESSOR_ARCHITECTURE%"=="AMD64" goto amd64
+if "%PROCESSOR_ARCHITECTURE%"=="IA64" goto ia64
+set _WRAPPER_L_EXE="%_REALPATH:"=%%_WRAPPER_BASE%-windows-x86-32.exe"
+goto search
+:amd64
+set _WRAPPER_L_EXE="%_REALPATH:"=%%_WRAPPER_BASE%-windows-x86-64.exe"
+goto search
+:ia64
+set _WRAPPER_L_EXE="%_REALPATH:"=%%_WRAPPER_BASE%-windows-ia-64.exe"
+goto search
+:search
+set _WRAPPER_EXE="%_WRAPPER_L_EXE:"=%"
+if exist %_WRAPPER_EXE% goto conf
+set _WRAPPER_EXE="%_REALPATH:"=%%_WRAPPER_BASE%.exe"
+if exist %_WRAPPER_EXE% goto conf
+echo Unable to locate a Wrapper executable using any of the following names:
+echo %_WRAPPER_L_EXE%
+echo %_WRAPPER_EXE%
+pause
+goto :eof
+
+rem
+rem Find the wrapper.conf
+rem
+:conf
+if [%_WRAPPER_CONF_OVERRIDE%]==[true] (
+ set _WRAPPER_CONF="%~f1"
+ if not [%_WRAPPER_CONF%]==[""] (
+ shift
+ goto :startup
+ )
+)
+set _WRAPPER_CONF="%_WRAPPER_CONF_DEFAULT:"=%"
+
+rem
+rem Start the Wrapper
+rem
+:startup
+if not [%_PASS_THROUGH%]==[true] (
+ if not [%1]==[] (
+ echo WARNING: Extra arguments will be ignored. Please check usage in the batch file.
+ )
+)
+
+rem Collect the application parameters
+:parameters
+set _PARAMETERS=%_PARAMETERS% %1
+shift
+if not [%1]==[] goto :parameters
+
+if not [%_PASS_THROUGH%]==[true] (
+ %_WRAPPER_EXE% -a %_WRAPPER_CONF%
+) else (
+ %_WRAPPER_EXE% -a %_WRAPPER_CONF% -- %_PARAMETERS%
+)
+if not errorlevel 1 goto :eof
+pause
diff --git a/food-open/food-open-api/src/main/bin/query.bat b/food-open/food-open-api/src/main/bin/query.bat
new file mode 100644
index 0000000..5638a44
--- /dev/null
+++ b/food-open/food-open-api/src/main/bin/query.bat
@@ -0,0 +1,135 @@
+@echo off
+setlocal
+
+rem
+rem Copyright (c) 1999, 2016 Tanuki Software, Ltd.
+rem http://www.tanukisoftware.com
+rem All rights reserved.
+rem
+rem This software is the proprietary information of Tanuki Software.
+rem You shall use it only in accordance with the terms of the
+rem license agreement you entered into with Tanuki Software.
+rem http://wrapper.tanukisoftware.com/doc/english/licenseOverview.html
+rem
+rem Java Service Wrapper general startup script.
+rem
+
+rem -----------------------------------------------------------------------------
+rem These settings can be modified to fit the needs of your application
+rem Optimized for use with version 3.5.28 of the Wrapper.
+
+rem The base name for the Wrapper binary.
+set _WRAPPER_BASE=wrapper
+
+rem The directory where the Wrapper binary (.exe) file is located. It can be
+rem either an absolute or a relative path. If the path contains any special
+rem characters, please make sure to quote the variable.
+set _WRAPPER_DIR=
+
+rem The name and location of the Wrapper configuration file. This will be used
+rem if the user does not specify a configuration file as the first parameter to
+rem this script.
+set _WRAPPER_CONF_DEFAULT="../conf/%_WRAPPER_BASE%.conf"
+
+rem Makes it possible to override the Wrapper configuration file by specifying it
+rem as the first parameter.
+rem set _WRAPPER_CONF_OVERRIDE=true
+
+rem Note that it is only possible to pass parameters through to the JVM when
+rem installing the service, or when running in a console.
+
+rem Do not modify anything beyond this point
+rem -----------------------------------------------------------------------------
+
+rem
+rem Resolve the real path of the wrapper.exe
+rem For non NT systems, the _REALPATH and _WRAPPER_CONF values
+rem can be hard-coded below and the following test removed.
+rem
+if "%OS%"=="Windows_NT" goto nt
+echo This script only works with NT-based versions of Windows.
+goto :eof
+
+:nt
+rem Find the application home.
+rem if no path path specified do the default action
+IF not DEFINED _WRAPPER_DIR goto dir_undefined
+set _WRAPPER_DIR_QUOTED="%_WRAPPER_DIR:"=%"
+if not "%_WRAPPER_DIR:~-2,1%" == "\" set _WRAPPER_DIR_QUOTED="%_WRAPPER_DIR_QUOTED:"=%\"
+rem check if absolute path
+if "%_WRAPPER_DIR_QUOTED:~2,1%" == ":" goto absolute_path
+if "%_WRAPPER_DIR_QUOTED:~1,1%" == "\" goto absolute_path
+rem everythig else means relative path
+set _REALPATH="%~dp0%_WRAPPER_DIR_QUOTED:"=%"
+goto pathfound
+
+:dir_undefined
+rem Use a relative path to the wrapper %~dp0 is location of current script under NT
+set _REALPATH="%~dp0"
+goto pathfound
+:absolute_path
+rem Use an absolute path to the wrapper
+set _REALPATH="%_WRAPPER_DIR_QUOTED:"=%"
+
+:pathfound
+rem
+rem Decide on the specific Wrapper binary to use (See delta-pack)
+rem
+if "%PROCESSOR_ARCHITEW6432%"=="AMD64" goto amd64
+if "%PROCESSOR_ARCHITECTURE%"=="AMD64" goto amd64
+if "%PROCESSOR_ARCHITECTURE%"=="IA64" goto ia64
+set _WRAPPER_L_EXE="%_REALPATH:"=%%_WRAPPER_BASE%-windows-x86-32.exe"
+goto search
+:amd64
+set _WRAPPER_L_EXE="%_REALPATH:"=%%_WRAPPER_BASE%-windows-x86-64.exe"
+goto search
+:ia64
+set _WRAPPER_L_EXE="%_REALPATH:"=%%_WRAPPER_BASE%-windows-ia-64.exe"
+goto search
+:search
+set _WRAPPER_EXE="%_WRAPPER_L_EXE:"=%"
+if exist %_WRAPPER_EXE% goto conf
+set _WRAPPER_EXE="%_REALPATH:"=%%_WRAPPER_BASE%.exe"
+if exist %_WRAPPER_EXE% goto conf
+echo Unable to locate a Wrapper executable using any of the following names:
+echo %_WRAPPER_L_EXE%
+echo %_WRAPPER_EXE%
+pause
+goto :eof
+
+rem
+rem Find the wrapper.conf
+rem
+:conf
+if [%_WRAPPER_CONF_OVERRIDE%]==[true] (
+ set _WRAPPER_CONF="%~f1"
+ if not [%_WRAPPER_CONF%]==[""] (
+ shift
+ goto :startup
+ )
+)
+set _WRAPPER_CONF="%_WRAPPER_CONF_DEFAULT:"=%"
+
+rem
+rem Start the Wrapper
+rem
+:startup
+if not [%_PASS_THROUGH%]==[true] (
+ if not [%1]==[] (
+ echo WARNING: Extra arguments will be ignored. Please check usage in the batch file.
+ )
+)
+
+rem Collect the application parameters
+:parameters
+set _PARAMETERS=%_PARAMETERS% %1
+shift
+if not [%1]==[] goto :parameters
+
+if not [%_PASS_THROUGH%]==[true] (
+ %_WRAPPER_EXE% -q %_WRAPPER_CONF%
+) else (
+ %_WRAPPER_EXE% -q %_WRAPPER_CONF% -- %_PARAMETERS%
+)
+if not errorlevel 1 goto :eof
+pause
diff --git a/food-open/food-open-api/src/main/bin/resume.bat b/food-open/food-open-api/src/main/bin/resume.bat
new file mode 100644
index 0000000..8b4d6ea
--- /dev/null
+++ b/food-open/food-open-api/src/main/bin/resume.bat
@@ -0,0 +1,135 @@
+@echo off
+setlocal
+
+rem
+rem Copyright (c) 1999, 2016 Tanuki Software, Ltd.
+rem http://www.tanukisoftware.com
+rem All rights reserved.
+rem
+rem This software is the proprietary information of Tanuki Software.
+rem You shall use it only in accordance with the terms of the
+rem license agreement you entered into with Tanuki Software.
+rem http://wrapper.tanukisoftware.com/doc/english/licenseOverview.html
+rem
+rem Java Service Wrapper general startup script.
+rem
+
+rem -----------------------------------------------------------------------------
+rem These settings can be modified to fit the needs of your application
+rem Optimized for use with version 3.5.28 of the Wrapper.
+
+rem The base name for the Wrapper binary.
+set _WRAPPER_BASE=wrapper
+
+rem The directory where the Wrapper binary (.exe) file is located. It can be
+rem either an absolute or a relative path. If the path contains any special
+rem characters, please make sure to quote the variable.
+set _WRAPPER_DIR=
+
+rem The name and location of the Wrapper configuration file. This will be used
+rem if the user does not specify a configuration file as the first parameter to
+rem this script.
+set _WRAPPER_CONF_DEFAULT="../conf/%_WRAPPER_BASE%.conf"
+
+rem Makes it possible to override the Wrapper configuration file by specifying it
+rem as the first parameter.
+rem set _WRAPPER_CONF_OVERRIDE=true
+
+rem Note that it is only possible to pass parameters through to the JVM when
+rem installing the service, or when running in a console.
+
+rem Do not modify anything beyond this point
+rem -----------------------------------------------------------------------------
+
+rem
+rem Resolve the real path of the wrapper.exe
+rem For non NT systems, the _REALPATH and _WRAPPER_CONF values
+rem can be hard-coded below and the following test removed.
+rem
+if "%OS%"=="Windows_NT" goto nt
+echo This script only works with NT-based versions of Windows.
+goto :eof
+
+:nt
+rem Find the application home.
+rem if no path path specified do the default action
+IF not DEFINED _WRAPPER_DIR goto dir_undefined
+set _WRAPPER_DIR_QUOTED="%_WRAPPER_DIR:"=%"
+if not "%_WRAPPER_DIR:~-2,1%" == "\" set _WRAPPER_DIR_QUOTED="%_WRAPPER_DIR_QUOTED:"=%\"
+rem check if absolute path
+if "%_WRAPPER_DIR_QUOTED:~2,1%" == ":" goto absolute_path
+if "%_WRAPPER_DIR_QUOTED:~1,1%" == "\" goto absolute_path
+rem everythig else means relative path
+set _REALPATH="%~dp0%_WRAPPER_DIR_QUOTED:"=%"
+goto pathfound
+
+:dir_undefined
+rem Use a relative path to the wrapper %~dp0 is location of current script under NT
+set _REALPATH="%~dp0"
+goto pathfound
+:absolute_path
+rem Use an absolute path to the wrapper
+set _REALPATH="%_WRAPPER_DIR_QUOTED:"=%"
+
+:pathfound
+rem
+rem Decide on the specific Wrapper binary to use (See delta-pack)
+rem
+if "%PROCESSOR_ARCHITEW6432%"=="AMD64" goto amd64
+if "%PROCESSOR_ARCHITECTURE%"=="AMD64" goto amd64
+if "%PROCESSOR_ARCHITECTURE%"=="IA64" goto ia64
+set _WRAPPER_L_EXE="%_REALPATH:"=%%_WRAPPER_BASE%-windows-x86-32.exe"
+goto search
+:amd64
+set _WRAPPER_L_EXE="%_REALPATH:"=%%_WRAPPER_BASE%-windows-x86-64.exe"
+goto search
+:ia64
+set _WRAPPER_L_EXE="%_REALPATH:"=%%_WRAPPER_BASE%-windows-ia-64.exe"
+goto search
+:search
+set _WRAPPER_EXE="%_WRAPPER_L_EXE:"=%"
+if exist %_WRAPPER_EXE% goto conf
+set _WRAPPER_EXE="%_REALPATH:"=%%_WRAPPER_BASE%.exe"
+if exist %_WRAPPER_EXE% goto conf
+echo Unable to locate a Wrapper executable using any of the following names:
+echo %_WRAPPER_L_EXE%
+echo %_WRAPPER_EXE%
+pause
+goto :eof
+
+rem
+rem Find the wrapper.conf
+rem
+:conf
+if [%_WRAPPER_CONF_OVERRIDE%]==[true] (
+ set _WRAPPER_CONF="%~f1"
+ if not [%_WRAPPER_CONF%]==[""] (
+ shift
+ goto :startup
+ )
+)
+set _WRAPPER_CONF="%_WRAPPER_CONF_DEFAULT:"=%"
+
+rem
+rem Start the Wrapper
+rem
+:startup
+if not [%_PASS_THROUGH%]==[true] (
+ if not [%1]==[] (
+ echo WARNING: Extra arguments will be ignored. Please check usage in the batch file.
+ )
+)
+
+rem Collect the application parameters
+:parameters
+set _PARAMETERS=%_PARAMETERS% %1
+shift
+if not [%1]==[] goto :parameters
+
+if not [%_PASS_THROUGH%]==[true] (
+ %_WRAPPER_EXE% -e %_WRAPPER_CONF%
+) else (
+ %_WRAPPER_EXE% -e %_WRAPPER_CONF% -- %_PARAMETERS%
+)
+if not errorlevel 1 goto :eof
+pause
diff --git a/food-open/food-open-api/src/main/bin/run.bat b/food-open/food-open-api/src/main/bin/run.bat
new file mode 100644
index 0000000..8672708
--- /dev/null
+++ b/food-open/food-open-api/src/main/bin/run.bat
@@ -0,0 +1,156 @@
+@echo off
+setlocal
+
+rem
+rem Copyright (c) 1999, 2016 Tanuki Software, Ltd.
+rem http://www.tanukisoftware.com
+rem All rights reserved.
+rem
+rem This software is the proprietary information of Tanuki Software.
+rem You shall use it only in accordance with the terms of the
+rem license agreement you entered into with Tanuki Software.
+rem http://wrapper.tanukisoftware.com/doc/english/licenseOverview.html
+rem
+rem Java Service Wrapper general passthrough startup script.
+rem
+
+rem -----------------------------------------------------------------------------
+rem These settings can be modified to fit the needs of your application
+rem Optimized for use with version 3.5.28 of the Wrapper.
+rem
+rem ********************************************************************
+rem NOTE - This script has been modified to run the TestWrapper sample
+rem application and should NOT be used as a base for your own
+rem applications. All of the documentation assumes that you are
+rem working from the default source script:
+rem WRAPPER_HOME/src/bin/App.bat.in
+rem ********************************************************************
+rem
+rem ********************************************************************
+rem NOTE - This script has been modified to run the TestWrapper sample
+rem application and should NOT be used as a base for your own
+rem applications. All of the documentation assumes that you are
+rem working from the default source script:
+rem WRAPPER_HOME/src/bin/App.bat.in
+rem ********************************************************************
+
+rem The base name for the Wrapper binary.
+set _WRAPPER_BASE=wrapper
+
+rem The directory where the Wrapper binary (.exe) file is located. It can be
+rem either an absolute or a relative path. If the path contains any special
+rem characters, please make sure to quote the variable.
+set _WRAPPER_DIR=
+
+rem The name and location of the Wrapper configuration file. This will be used
+rem if the user does not specify a configuration file as the first parameter to
+rem this script.
+set _WRAPPER_CONF_DEFAULT="../conf/%_WRAPPER_BASE%.conf"
+
+rem Makes it possible to override the Wrapper configuration file by specifying it
+rem as the first parameter.
+rem set _WRAPPER_CONF_OVERRIDE=true
+
+rem _PASS_THROUGH tells the script to pass all parameters through to the JVM
+rem as is.
+rem If _WRAPPER_CONF_OVERRIDE is specified then all parameters will be passed.
+rem If not set then all parameters starting with the second will be passed.
+set _PASS_THROUGH=true
+
+rem Do not modify anything beyond this point
+rem -----------------------------------------------------------------------------
+
+rem
+rem Resolve the real path of the wrapper.exe
+rem For non NT systems, the _REALPATH and _WRAPPER_CONF values
+rem can be hard-coded below and the following test removed.
+rem
+if "%OS%"=="Windows_NT" goto nt
+echo This script only works with NT-based versions of Windows.
+goto :eof
+
+:nt
+rem Find the application home.
+rem if no path path specified do the default action
+IF not DEFINED _WRAPPER_DIR goto dir_undefined
+set _WRAPPER_DIR_QUOTED="%_WRAPPER_DIR:"=%"
+if not "%_WRAPPER_DIR:~-2,1%" == "\" set _WRAPPER_DIR_QUOTED="%_WRAPPER_DIR_QUOTED:"=%\"
+rem check if absolute path
+if "%_WRAPPER_DIR_QUOTED:~2,1%" == ":" goto absolute_path
+if "%_WRAPPER_DIR_QUOTED:~1,1%" == "\" goto absolute_path
+rem everythig else means relative path
+set _REALPATH="%~dp0%_WRAPPER_DIR_QUOTED:"=%"
+goto pathfound
+
+:dir_undefined
+rem Use a relative path to the wrapper %~dp0 is location of current script under NT
+set _REALPATH="%~dp0"
+goto pathfound
+:absolute_path
+rem Use an absolute path to the wrapper
+set _REALPATH="%_WRAPPER_DIR_QUOTED:"=%"
+
+:pathfound
+rem
+rem Decide on the specific Wrapper binary to use (See delta-pack)
+rem
+if "%PROCESSOR_ARCHITEW6432%"=="AMD64" goto amd64
+if "%PROCESSOR_ARCHITECTURE%"=="AMD64" goto amd64
+if "%PROCESSOR_ARCHITECTURE%"=="IA64" goto ia64
+set _WRAPPER_L_EXE="%_REALPATH:"=%%_WRAPPER_BASE%-windows-x86-32.exe"
+goto search
+:amd64
+set _WRAPPER_L_EXE="%_REALPATH:"=%%_WRAPPER_BASE%-windows-x86-64.exe"
+goto search
+:ia64
+set _WRAPPER_L_EXE="%_REALPATH:"=%%_WRAPPER_BASE%-windows-ia-64.exe"
+goto search
+:search
+set _WRAPPER_EXE="%_WRAPPER_L_EXE:"=%"
+if exist %_WRAPPER_EXE% goto conf
+set _WRAPPER_EXE="%_REALPATH:"=%%_WRAPPER_BASE%.exe"
+if exist %_WRAPPER_EXE% goto conf
+echo Unable to locate a Wrapper executable using any of the following names:
+echo %_WRAPPER_L_EXE%
+echo %_WRAPPER_EXE%
+pause
+goto :eof
+
+rem
+rem Find the wrapper.conf
+rem
+:conf
+if [%_WRAPPER_CONF_OVERRIDE%]==[true] (
+ set _WRAPPER_CONF="%~f1"
+ if not [%_WRAPPER_CONF%]==[""] (
+ shift
+ goto :startup
+ )
+)
+set _WRAPPER_CONF="%_WRAPPER_CONF_DEFAULT:"=%"
+
+rem
+rem Start the Wrapper
+rem
+:startup
+if not [%_PASS_THROUGH%]==[true] (
+ if not [%1]==[] (
+ echo WARNING: Extra arguments will be ignored. Please check usage in the batch file.
+ )
+)
+
+rem Collect the application parameters
+:parameters
+set _PARAMETERS=%_PARAMETERS% %1
+shift
+if not [%1]==[] goto :parameters
+
+if not [%_PASS_THROUGH%]==[true] (
+ %_WRAPPER_EXE% -c %_WRAPPER_CONF%
+) else (
+ %_WRAPPER_EXE% -c %_WRAPPER_CONF% -- %_PARAMETERS%
+)
+if not errorlevel 1 goto :eof
+pause
+
+
diff --git a/food-open/food-open-api/src/main/bin/start.bat b/food-open/food-open-api/src/main/bin/start.bat
new file mode 100644
index 0000000..d7d5e85
--- /dev/null
+++ b/food-open/food-open-api/src/main/bin/start.bat
@@ -0,0 +1,135 @@
+@echo off
+setlocal
+
+rem
+rem Copyright (c) 1999, 2016 Tanuki Software, Ltd.
+rem http://www.tanukisoftware.com
+rem All rights reserved.
+rem
+rem This software is the proprietary information of Tanuki Software.
+rem You shall use it only in accordance with the terms of the
+rem license agreement you entered into with Tanuki Software.
+rem http://wrapper.tanukisoftware.com/doc/english/licenseOverview.html
+rem
+rem Java Service Wrapper general startup script.
+rem
+
+rem -----------------------------------------------------------------------------
+rem These settings can be modified to fit the needs of your application
+rem Optimized for use with version 3.5.28 of the Wrapper.
+
+rem The base name for the Wrapper binary.
+set _WRAPPER_BASE=wrapper
+
+rem The directory where the Wrapper binary (.exe) file is located. It can be
+rem either an absolute or a relative path. If the path contains any special
+rem characters, please make sure to quote the variable.
+set _WRAPPER_DIR=
+
+rem The name and location of the Wrapper configuration file. This will be used
+rem if the user does not specify a configuration file as the first parameter to
+rem this script.
+set _WRAPPER_CONF_DEFAULT="../conf/%_WRAPPER_BASE%.conf"
+
+rem Makes it possible to override the Wrapper configuration file by specifying it
+rem as the first parameter.
+rem set _WRAPPER_CONF_OVERRIDE=true
+
+rem Note that it is only possible to pass parameters through to the JVM when
+rem installing the service, or when running in a console.
+
+rem Do not modify anything beyond this point
+rem -----------------------------------------------------------------------------
+
+rem
+rem Resolve the real path of the wrapper.exe
+rem For non NT systems, the _REALPATH and _WRAPPER_CONF values
+rem can be hard-coded below and the following test removed.
+rem
+if "%OS%"=="Windows_NT" goto nt
+echo This script only works with NT-based versions of Windows.
+goto :eof
+
+:nt
+rem Find the application home.
+rem if no path path specified do the default action
+IF not DEFINED _WRAPPER_DIR goto dir_undefined
+set _WRAPPER_DIR_QUOTED="%_WRAPPER_DIR:"=%"
+if not "%_WRAPPER_DIR:~-2,1%" == "\" set _WRAPPER_DIR_QUOTED="%_WRAPPER_DIR_QUOTED:"=%\"
+rem check if absolute path
+if "%_WRAPPER_DIR_QUOTED:~2,1%" == ":" goto absolute_path
+if "%_WRAPPER_DIR_QUOTED:~1,1%" == "\" goto absolute_path
+rem everythig else means relative path
+set _REALPATH="%~dp0%_WRAPPER_DIR_QUOTED:"=%"
+goto pathfound
+
+:dir_undefined
+rem Use a relative path to the wrapper %~dp0 is location of current script under NT
+set _REALPATH="%~dp0"
+goto pathfound
+:absolute_path
+rem Use an absolute path to the wrapper
+set _REALPATH="%_WRAPPER_DIR_QUOTED:"=%"
+
+:pathfound
+rem
+rem Decide on the specific Wrapper binary to use (See delta-pack)
+rem
+if "%PROCESSOR_ARCHITEW6432%"=="AMD64" goto amd64
+if "%PROCESSOR_ARCHITECTURE%"=="AMD64" goto amd64
+if "%PROCESSOR_ARCHITECTURE%"=="IA64" goto ia64
+set _WRAPPER_L_EXE="%_REALPATH:"=%%_WRAPPER_BASE%-windows-x86-32.exe"
+goto search
+:amd64
+set _WRAPPER_L_EXE="%_REALPATH:"=%%_WRAPPER_BASE%-windows-x86-64.exe"
+goto search
+:ia64
+set _WRAPPER_L_EXE="%_REALPATH:"=%%_WRAPPER_BASE%-windows-ia-64.exe"
+goto search
+:search
+set _WRAPPER_EXE="%_WRAPPER_L_EXE:"=%"
+if exist %_WRAPPER_EXE% goto conf
+set _WRAPPER_EXE="%_REALPATH:"=%%_WRAPPER_BASE%.exe"
+if exist %_WRAPPER_EXE% goto conf
+echo Unable to locate a Wrapper executable using any of the following names:
+echo %_WRAPPER_L_EXE%
+echo %_WRAPPER_EXE%
+pause
+goto :eof
+
+rem
+rem Find the wrapper.conf
+rem
+:conf
+if [%_WRAPPER_CONF_OVERRIDE%]==[true] (
+ set _WRAPPER_CONF="%~f1"
+ if not [%_WRAPPER_CONF%]==[""] (
+ shift
+ goto :startup
+ )
+)
+set _WRAPPER_CONF="%_WRAPPER_CONF_DEFAULT:"=%"
+
+rem
+rem Start the Wrapper
+rem
+:startup
+if not [%_PASS_THROUGH%]==[true] (
+ if not [%1]==[] (
+ echo WARNING: Extra arguments will be ignored. Please check usage in the batch file.
+ )
+)
+
+rem Collect the application parameters
+:parameters
+set _PARAMETERS=%_PARAMETERS% %1
+shift
+if not [%1]==[] goto :parameters
+
+if not [%_PASS_THROUGH%]==[true] (
+ %_WRAPPER_EXE% -t %_WRAPPER_CONF%
+) else (
+ %_WRAPPER_EXE% -t %_WRAPPER_CONF% -- %_PARAMETERS%
+)
+if not errorlevel 1 goto :eof
+pause
diff --git a/food-open/food-open-api/src/main/bin/stop.bat b/food-open/food-open-api/src/main/bin/stop.bat
new file mode 100644
index 0000000..49d717c
--- /dev/null
+++ b/food-open/food-open-api/src/main/bin/stop.bat
@@ -0,0 +1,135 @@
+@echo off
+setlocal
+
+rem
+rem Copyright (c) 1999, 2016 Tanuki Software, Ltd.
+rem http://www.tanukisoftware.com
+rem All rights reserved.
+rem
+rem This software is the proprietary information of Tanuki Software.
+rem You shall use it only in accordance with the terms of the
+rem license agreement you entered into with Tanuki Software.
+rem http://wrapper.tanukisoftware.com/doc/english/licenseOverview.html
+rem
+rem Java Service Wrapper general startup script.
+rem
+
+rem -----------------------------------------------------------------------------
+rem These settings can be modified to fit the needs of your application
+rem Optimized for use with version 3.5.28 of the Wrapper.
+
+rem The base name for the Wrapper binary.
+set _WRAPPER_BASE=wrapper
+
+rem The directory where the Wrapper binary (.exe) file is located. It can be
+rem either an absolute or a relative path. If the path contains any special
+rem characters, please make sure to quote the variable.
+set _WRAPPER_DIR=
+
+rem The name and location of the Wrapper configuration file. This will be used
+rem if the user does not specify a configuration file as the first parameter to
+rem this script.
+set _WRAPPER_CONF_DEFAULT="../conf/%_WRAPPER_BASE%.conf"
+
+rem Makes it possible to override the Wrapper configuration file by specifying it
+rem as the first parameter.
+rem set _WRAPPER_CONF_OVERRIDE=true
+
+rem Note that it is only possible to pass parameters through to the JVM when
+rem installing the service, or when running in a console.
+
+rem Do not modify anything beyond this point
+rem -----------------------------------------------------------------------------
+
+rem
+rem Resolve the real path of the wrapper.exe
+rem For non NT systems, the _REALPATH and _WRAPPER_CONF values
+rem can be hard-coded below and the following test removed.
+rem
+if "%OS%"=="Windows_NT" goto nt
+echo This script only works with NT-based versions of Windows.
+goto :eof
+
+:nt
+rem Find the application home.
+rem if no path path specified do the default action
+IF not DEFINED _WRAPPER_DIR goto dir_undefined
+set _WRAPPER_DIR_QUOTED="%_WRAPPER_DIR:"=%"
+if not "%_WRAPPER_DIR:~-2,1%" == "\" set _WRAPPER_DIR_QUOTED="%_WRAPPER_DIR_QUOTED:"=%\"
+rem check if absolute path
+if "%_WRAPPER_DIR_QUOTED:~2,1%" == ":" goto absolute_path
+if "%_WRAPPER_DIR_QUOTED:~1,1%" == "\" goto absolute_path
+rem everythig else means relative path
+set _REALPATH="%~dp0%_WRAPPER_DIR_QUOTED:"=%"
+goto pathfound
+
+:dir_undefined
+rem Use a relative path to the wrapper %~dp0 is location of current script under NT
+set _REALPATH="%~dp0"
+goto pathfound
+:absolute_path
+rem Use an absolute path to the wrapper
+set _REALPATH="%_WRAPPER_DIR_QUOTED:"=%"
+
+:pathfound
+rem
+rem Decide on the specific Wrapper binary to use (See delta-pack)
+rem
+if "%PROCESSOR_ARCHITEW6432%"=="AMD64" goto amd64
+if "%PROCESSOR_ARCHITECTURE%"=="AMD64" goto amd64
+if "%PROCESSOR_ARCHITECTURE%"=="IA64" goto ia64
+set _WRAPPER_L_EXE="%_REALPATH:"=%%_WRAPPER_BASE%-windows-x86-32.exe"
+goto search
+:amd64
+set _WRAPPER_L_EXE="%_REALPATH:"=%%_WRAPPER_BASE%-windows-x86-64.exe"
+goto search
+:ia64
+set _WRAPPER_L_EXE="%_REALPATH:"=%%_WRAPPER_BASE%-windows-ia-64.exe"
+goto search
+:search
+set _WRAPPER_EXE="%_WRAPPER_L_EXE:"=%"
+if exist %_WRAPPER_EXE% goto conf
+set _WRAPPER_EXE="%_REALPATH:"=%%_WRAPPER_BASE%.exe"
+if exist %_WRAPPER_EXE% goto conf
+echo Unable to locate a Wrapper executable using any of the following names:
+echo %_WRAPPER_L_EXE%
+echo %_WRAPPER_EXE%
+pause
+goto :eof
+
+rem
+rem Find the wrapper.conf
+rem
+:conf
+if [%_WRAPPER_CONF_OVERRIDE%]==[true] (
+ set _WRAPPER_CONF="%~f1"
+ if not [%_WRAPPER_CONF%]==[""] (
+ shift
+ goto :startup
+ )
+)
+set _WRAPPER_CONF="%_WRAPPER_CONF_DEFAULT:"=%"
+
+rem
+rem Start the Wrapper
+rem
+:startup
+if not [%_PASS_THROUGH%]==[true] (
+ if not [%1]==[] (
+ echo WARNING: Extra arguments will be ignored. Please check usage in the batch file.
+ )
+)
+
+rem Collect the application parameters
+:parameters
+set _PARAMETERS=%_PARAMETERS% %1
+shift
+if not [%1]==[] goto :parameters
+
+if not [%_PASS_THROUGH%]==[true] (
+ %_WRAPPER_EXE% -p %_WRAPPER_CONF%
+) else (
+ %_WRAPPER_EXE% -p %_WRAPPER_CONF% -- %_PARAMETERS%
+)
+if not errorlevel 1 goto :eof
+pause
diff --git a/food-open/food-open-api/src/main/bin/uninstall.bat b/food-open/food-open-api/src/main/bin/uninstall.bat
new file mode 100644
index 0000000..6ee6d07
--- /dev/null
+++ b/food-open/food-open-api/src/main/bin/uninstall.bat
@@ -0,0 +1,135 @@
+@echo off
+setlocal
+
+rem
+rem Copyright (c) 1999, 2016 Tanuki Software, Ltd.
+rem http://www.tanukisoftware.com
+rem All rights reserved.
+rem
+rem This software is the proprietary information of Tanuki Software.
+rem You shall use it only in accordance with the terms of the
+rem license agreement you entered into with Tanuki Software.
+rem http://wrapper.tanukisoftware.com/doc/english/licenseOverview.html
+rem
+rem Java Service Wrapper general startup script.
+rem
+
+rem -----------------------------------------------------------------------------
+rem These settings can be modified to fit the needs of your application
+rem Optimized for use with version 3.5.28 of the Wrapper.
+
+rem The base name for the Wrapper binary.
+set _WRAPPER_BASE=wrapper
+
+rem The directory where the Wrapper binary (.exe) file is located. It can be
+rem either an absolute or a relative path. If the path contains any special
+rem characters, please make sure to quote the variable.
+set _WRAPPER_DIR=
+
+rem The name and location of the Wrapper configuration file. This will be used
+rem if the user does not specify a configuration file as the first parameter to
+rem this script.
+set _WRAPPER_CONF_DEFAULT="../conf/%_WRAPPER_BASE%.conf"
+
+rem Makes it possible to override the Wrapper configuration file by specifying it
+rem as the first parameter.
+rem set _WRAPPER_CONF_OVERRIDE=true
+
+rem Note that it is only possible to pass parameters through to the JVM when
+rem installing the service, or when running in a console.
+
+rem Do not modify anything beyond this point
+rem -----------------------------------------------------------------------------
+
+rem
+rem Resolve the real path of the wrapper.exe
+rem For non NT systems, the _REALPATH and _WRAPPER_CONF values
+rem can be hard-coded below and the following test removed.
+rem
+if "%OS%"=="Windows_NT" goto nt
+echo This script only works with NT-based versions of Windows.
+goto :eof
+
+:nt
+rem Find the application home.
+rem if no path path specified do the default action
+IF not DEFINED _WRAPPER_DIR goto dir_undefined
+set _WRAPPER_DIR_QUOTED="%_WRAPPER_DIR:"=%"
+if not "%_WRAPPER_DIR:~-2,1%" == "\" set _WRAPPER_DIR_QUOTED="%_WRAPPER_DIR_QUOTED:"=%\"
+rem check if absolute path
+if "%_WRAPPER_DIR_QUOTED:~2,1%" == ":" goto absolute_path
+if "%_WRAPPER_DIR_QUOTED:~1,1%" == "\" goto absolute_path
+rem everythig else means relative path
+set _REALPATH="%~dp0%_WRAPPER_DIR_QUOTED:"=%"
+goto pathfound
+
+:dir_undefined
+rem Use a relative path to the wrapper %~dp0 is location of current script under NT
+set _REALPATH="%~dp0"
+goto pathfound
+:absolute_path
+rem Use an absolute path to the wrapper
+set _REALPATH="%_WRAPPER_DIR_QUOTED:"=%"
+
+:pathfound
+rem
+rem Decide on the specific Wrapper binary to use (See delta-pack)
+rem
+if "%PROCESSOR_ARCHITEW6432%"=="AMD64" goto amd64
+if "%PROCESSOR_ARCHITECTURE%"=="AMD64" goto amd64
+if "%PROCESSOR_ARCHITECTURE%"=="IA64" goto ia64
+set _WRAPPER_L_EXE="%_REALPATH:"=%%_WRAPPER_BASE%-windows-x86-32.exe"
+goto search
+:amd64
+set _WRAPPER_L_EXE="%_REALPATH:"=%%_WRAPPER_BASE%-windows-x86-64.exe"
+goto search
+:ia64
+set _WRAPPER_L_EXE="%_REALPATH:"=%%_WRAPPER_BASE%-windows-ia-64.exe"
+goto search
+:search
+set _WRAPPER_EXE="%_WRAPPER_L_EXE:"=%"
+if exist %_WRAPPER_EXE% goto conf
+set _WRAPPER_EXE="%_REALPATH:"=%%_WRAPPER_BASE%.exe"
+if exist %_WRAPPER_EXE% goto conf
+echo Unable to locate a Wrapper executable using any of the following names:
+echo %_WRAPPER_L_EXE%
+echo %_WRAPPER_EXE%
+pause
+goto :eof
+
+rem
+rem Find the wrapper.conf
+rem
+:conf
+if [%_WRAPPER_CONF_OVERRIDE%]==[true] (
+ set _WRAPPER_CONF="%~f1"
+ if not [%_WRAPPER_CONF%]==[""] (
+ shift
+ goto :startup
+ )
+)
+set _WRAPPER_CONF="%_WRAPPER_CONF_DEFAULT:"=%"
+
+rem
+rem Start the Wrapper
+rem
+:startup
+if not [%_PASS_THROUGH%]==[true] (
+ if not [%1]==[] (
+ echo WARNING: Extra arguments will be ignored. Please check usage in the batch file.
+ )
+)
+
+rem Collect the application parameters
+:parameters
+set _PARAMETERS=%_PARAMETERS% %1
+shift
+if not [%1]==[] goto :parameters
+
+if not [%_PASS_THROUGH%]==[true] (
+ %_WRAPPER_EXE% -r %_WRAPPER_CONF%
+) else (
+ %_WRAPPER_EXE% -r %_WRAPPER_CONF% -- %_PARAMETERS%
+)
+if not errorlevel 1 goto :eof
+pause
diff --git a/food-open/food-open-api/src/main/bin/wrapper-linux-x86-32 b/food-open/food-open-api/src/main/bin/wrapper-linux-x86-32
new file mode 100644
index 0000000..ff3509f
Binary files /dev/null and b/food-open/food-open-api/src/main/bin/wrapper-linux-x86-32 differ
diff --git a/food-open/food-open-api/src/main/bin/wrapper-linux-x86-64 b/food-open/food-open-api/src/main/bin/wrapper-linux-x86-64
new file mode 100644
index 0000000..e72b0e0
Binary files /dev/null and b/food-open/food-open-api/src/main/bin/wrapper-linux-x86-64 differ
diff --git a/food-open/food-open-api/src/main/bin/wrapper-macosx-universal-32 b/food-open/food-open-api/src/main/bin/wrapper-macosx-universal-32
new file mode 100644
index 0000000..9a36a5c
Binary files /dev/null and b/food-open/food-open-api/src/main/bin/wrapper-macosx-universal-32 differ
diff --git a/food-open/food-open-api/src/main/bin/wrapper-macosx-universal-64 b/food-open/food-open-api/src/main/bin/wrapper-macosx-universal-64
new file mode 100644
index 0000000..6587d2c
Binary files /dev/null and b/food-open/food-open-api/src/main/bin/wrapper-macosx-universal-64 differ
diff --git a/food-open/food-open-api/src/main/bin/wrapper-windows-x86-32.exe b/food-open/food-open-api/src/main/bin/wrapper-windows-x86-32.exe
new file mode 100644
index 0000000..9762dbf
Binary files /dev/null and b/food-open/food-open-api/src/main/bin/wrapper-windows-x86-32.exe differ
diff --git a/food-open/food-open-api/src/main/bin/wrapper-windows-x86-64.exe b/food-open/food-open-api/src/main/bin/wrapper-windows-x86-64.exe
new file mode 100644
index 0000000..122ec17
Binary files /dev/null and b/food-open/food-open-api/src/main/bin/wrapper-windows-x86-64.exe differ
diff --git a/food-open/food-open-api/src/main/conf/wrapper.conf b/food-open/food-open-api/src/main/conf/wrapper.conf
new file mode 100644
index 0000000..e249441
--- /dev/null
+++ b/food-open/food-open-api/src/main/conf/wrapper.conf
@@ -0,0 +1,60 @@
+encoding=UTF-8
+wrapper.lang=zh_CN
+#using the system default JDK environment variable
+wrapper.java.command=java
+#set.JAVA_HOME=/home/jdk1.8.0_65
+#wrapper.java.command=%JAVA_HOME%/bin/java
+wrapper.java.command.loglevel=INFO
+
+wrapper.java.mainclass=org.tanukisoftware.wrapper.WrapperSimpleApp
+wrapper.java.classpath.1=./
+wrapper.java.classpath.2=../conf/
+wrapper.java.classpath.3=../lib/*.jar
+
+wrapper.java.library.path.1=../lib
+
+wrapper.java.additional.auto_bits=TRUE
+#set the default parameters
+wrapper.java.additional.1=-Xms512m
+wrapper.java.additional.2=-Xmx1024m
+wrapper.java.additional.3=-XX:PermSize=256m
+wrapper.java.additional.4=-XX:MaxPermSize=512m
+wrapper.java.additional.5=-Djava.net.preferIPv4Stack=true
+wrapper.java.additional.6=-Dsun.lang.ClassLoader.allowArraySyntax=true
+
+# Initial Java Heap Size (in MB)
+wrapper.java.initmemory=128
+# Maximum Java Heap Size (in MB)
+wrapper.java.maxmemory=512
+
+# Application parameters. Add parameters as needed starting from 1
+wrapper.app.parameter.1=org.springframework.boot.loader.JarLauncher
+wrapper.app.parameter.2=--spring.config.location=../conf/application.properties
+wrapper.app.parameter.3=--logging.config=../conf/logback.xml
+wrapper.app.parameter.4=--logging.path=../logs
+
+wrapper.filter.trigger.1=java.lang.OutOfMemoryError
+wrapper.filter.action.1=RESTART
+
+wrapper.console.format=PM
+wrapper.console.loglevel=INFO
+
+wrapper.logfile=../logs/server_YYYYMMDD.log
+wrapper.logfile.rollmode=DATE
+wrapper.logfile.format=LPTM
+wrapper.logfile.loglevel=INFO
+wrapper.logfile.maxsize=0
+wrapper.logfile.maxfiles=0
+wrapper.syslog.loglevel=NONE
+
+wrapper.ignore_sequence_gaps=TRUE
+wrapper.pidfile.strict=TRUE
+
+wrapper.console.title=Food-2.0 Open Api Application
+
+wrapper.name=food2_open_api
+wrapper.displayname=Food-2.0 Open Api Application
+wrapper.description=Food-2.0 Open Api Application
+wrapper.ntservice.dependency.1=
+wrapper.ntservice.starttype=AUTO_START
+wrapper.ntservice.interactive=false
diff --git a/food-open/food-open-api/src/main/java/com/jwsaas/Application.java b/food-open/food-open-api/src/main/java/com/jwsaas/Application.java
new file mode 100644
index 0000000..e96659d
--- /dev/null
+++ b/food-open/food-open-api/src/main/java/com/jwsaas/Application.java
@@ -0,0 +1,19 @@
+package com.jwsaas;
+
+import org.springframework.boot.SpringApplication;
+import org.springframework.boot.autoconfigure.SpringBootApplication;
+import org.springframework.boot.web.servlet.ServletComponentScan;
+import org.springframework.context.annotation.ComponentScan;
+import org.springframework.context.annotation.ImportResource;
+
+@ComponentScan(basePackages = "com.jwsaas")
+@ServletComponentScan(basePackages = "com.jwsaas.servlet")
+@ImportResource(locations = { "classpath*:META-INF/spring/spring-*.xml" })
+@SpringBootApplication
+public class Application {
+
+ public static void main(String[] args) {
+ SpringApplication.run(Application.class, args);
+ }
+
+}
diff --git a/food-open/food-open-api/src/main/java/com/jwsaas/Constant.java b/food-open/food-open-api/src/main/java/com/jwsaas/Constant.java
new file mode 100644
index 0000000..cd99c67
--- /dev/null
+++ b/food-open/food-open-api/src/main/java/com/jwsaas/Constant.java
@@ -0,0 +1,30 @@
+package com.jwsaas;
+
+public class Constant {
+
+ /**
+ * 系统默认数据源标识
+ */
+ public static final String DEFAULT_DB_SIGN = "10001";
+
+ /**
+ * 系统默认创建人
+ */
+ public static final String CREATE_USER = "OpenApi";
+
+ /**
+ * 系统默认redis前缀
+ */
+ public static final String DEFAULT_REDIS_PREFIX = "food20OpenApi";
+
+ /**
+ * 公共部分标识(shared)
+ */
+ public static final String SHARED_SIGN = "shared";
+
+ /**
+ * 餐饮项目标识(food2)
+ */
+ public static final String FOOD_SIGN = "food2";
+
+}
diff --git a/food-open/food-open-api/src/main/java/com/jwsaas/Global.java b/food-open/food-open-api/src/main/java/com/jwsaas/Global.java
new file mode 100644
index 0000000..d8f9a80
--- /dev/null
+++ b/food-open/food-open-api/src/main/java/com/jwsaas/Global.java
@@ -0,0 +1,8 @@
+package com.jwsaas;
+
+public class Global {
+
+ public static final String APP_SIGN = "food";
+
+ public static final String DATA_LIMIT = "30000";
+}
diff --git a/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/AskTicketMoneyListRequest.java b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/AskTicketMoneyListRequest.java
new file mode 100644
index 0000000..f25fe43
--- /dev/null
+++ b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/AskTicketMoneyListRequest.java
@@ -0,0 +1,23 @@
+package com.jwsaas.api.boduo.erp.request;
+
+import com.jwsaas.api.request.AbstractRequest;
+
+import javax.validation.constraints.NotNull;
+
+/**
+ * @Author:CHL
+ * @Date:Create in 2018/04/02
+ * @Description: 在erp中获取要货单金额信息
+ */
+public class AskTicketMoneyListRequest extends AbstractRequest {
+ @NotNull
+ private String ticketId;
+ public String getTicketId() {
+ return ticketId;
+ }
+
+ public void setTicketId(String ticketId) {
+ this.ticketId = ticketId;
+ }
+
+}
diff --git a/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/CreateDispatchTicketRequest.java b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/CreateDispatchTicketRequest.java
new file mode 100644
index 0000000..57b778e
--- /dev/null
+++ b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/CreateDispatchTicketRequest.java
@@ -0,0 +1,81 @@
+package com.jwsaas.api.boduo.erp.request;
+
+
+import com.jwsaas.api.request.AbstractRequest;
+import com.jwsaas.open.annotation.IgnoreSign;
+
+import javax.validation.constraints.NotNull;
+
+/**
+ * Created by Administrator on 2019\9\25 0025.
+ */
+public class CreateDispatchTicketRequest extends AbstractRequest {
+
+ @NotNull
+ private String storeErpNo;//要货门店,定制erp门店编号;
+
+ @IgnoreSign
+ private Double logisticsFee;//物流费用
+
+ @IgnoreSign
+ private Double orderMoney;//原料费用;
+
+ @IgnoreSign
+ private Double otherFee;//其他费用;
+
+ @IgnoreSign
+ private String description;//备注;
+
+ @IgnoreSign
+ @NotNull
+ private String materialInfo;//要货信息;
+
+
+ public String getStoreErpNo() {
+ return storeErpNo;
+ }
+
+ public void setStoreErpNo(String storeErpNo) {
+ this.storeErpNo = storeErpNo;
+ }
+
+ public Double getLogisticsFee() {
+ return logisticsFee;
+ }
+
+ public void setLogisticsFee(Double logisticsFee) {
+ this.logisticsFee = logisticsFee;
+ }
+
+ public Double getOrderMoney() {
+ return orderMoney;
+ }
+
+ public void setOrderMoney(Double orderMoney) {
+ this.orderMoney = orderMoney;
+ }
+
+ public Double getOtherFee() {
+ return otherFee;
+ }
+
+ public void setOtherFee(Double otherFee) {
+ this.otherFee = otherFee;
+ }
+
+ public String getDescription() {
+ return description;
+ }
+
+ public void setDescription(String description) {
+ this.description = description;
+ }
+
+ public String getMaterialInfo() {
+ return materialInfo;
+ }
+
+ public void setMaterialInfo(String materialInfo) {
+ this.materialInfo = materialInfo;
+ }
+}
diff --git a/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/DeliveryModeListRequest.java b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/DeliveryModeListRequest.java
new file mode 100644
index 0000000..35d40a3
--- /dev/null
+++ b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/DeliveryModeListRequest.java
@@ -0,0 +1,14 @@
+package com.jwsaas.api.boduo.erp.request;
+
+import com.jwsaas.api.request.AbstractRequest;
+
+import javax.validation.constraints.NotNull;
+
+/**
+ * @Author:CHL
+ * @Date:Create in 2018/3/30
+ * @Description: erp中配送方式
+ */
+public class DeliveryModeListRequest extends AbstractRequest {
+
+}
diff --git a/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/DishToErpSyncRequest.java b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/DishToErpSyncRequest.java
new file mode 100644
index 0000000..7bf3f44
--- /dev/null
+++ b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/DishToErpSyncRequest.java
@@ -0,0 +1,23 @@
+package com.jwsaas.api.boduo.erp.request;
+
+import com.jwsaas.api.request.AbstractRequest;
+
+import javax.validation.constraints.NotNull;
+
+/**
+ * @Author:CHL
+ * @Date:Create in 2018/4/28
+ * @Description: pos中的数据向 erp中同步调用的接口
+ */
+public class DishToErpSyncRequest extends AbstractRequest {
+ @NotNull
+ private String dishJson; //菜品json
+
+ public String getDishJson() {
+ return dishJson;
+ }
+
+ public void setDishJson(String dishJson) {
+ this.dishJson = dishJson;
+ }
+}
diff --git a/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/ErpProductRatioRequest.java b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/ErpProductRatioRequest.java
new file mode 100644
index 0000000..986e46d
--- /dev/null
+++ b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/ErpProductRatioRequest.java
@@ -0,0 +1,8 @@
+package com.jwsaas.api.boduo.erp.request;
+
+import com.jwsaas.api.request.store.StoreBaseRequest;
+import com.jwsaas.open.annotation.IgnoreSign;
+
+public class ErpProductRatioRequest extends StoreBaseRequest {
+
+}
diff --git a/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/ErpProductRequest.java b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/ErpProductRequest.java
new file mode 100644
index 0000000..dc01347
--- /dev/null
+++ b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/ErpProductRequest.java
@@ -0,0 +1,9 @@
+package com.jwsaas.api.boduo.erp.request;
+
+import com.jwsaas.api.request.store.StoreBaseRequest;
+import com.jwsaas.open.annotation.IgnoreSign;
+
+public class ErpProductRequest extends StoreBaseRequest{
+
+
+}
diff --git a/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/ErpProductSpecRequest.java b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/ErpProductSpecRequest.java
new file mode 100644
index 0000000..bcce600
--- /dev/null
+++ b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/ErpProductSpecRequest.java
@@ -0,0 +1,8 @@
+package com.jwsaas.api.boduo.erp.request;
+
+import com.jwsaas.api.request.store.StoreBaseRequest;
+import com.jwsaas.open.annotation.IgnoreSign;
+
+public class ErpProductSpecRequest extends StoreBaseRequest{
+
+}
diff --git a/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/ErpStoreAskMaterialRequest.java b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/ErpStoreAskMaterialRequest.java
new file mode 100644
index 0000000..8eaa242
--- /dev/null
+++ b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/ErpStoreAskMaterialRequest.java
@@ -0,0 +1,34 @@
+package com.jwsaas.api.boduo.erp.request;
+
+import com.jwsaas.api.request.AbstractRequest;
+
+import javax.validation.constraints.NotNull;
+
+/**
+ * @Author:CHL
+ * @Date:Create in 2018/4/27
+ * @Description: erp中门店允许要货物料发生变化同步至pos
+ */
+public class ErpStoreAskMaterialRequest extends AbstractRequest {
+
+ @NotNull
+ private String customerNo; //erp客户编号
+ @NotNull
+ private String matePriceJson ; //erp中新物料编号与价格
+
+ public String getCustomerNo() {
+ return customerNo;
+ }
+
+ public void setCustomerNo(String customerNo) {
+ this.customerNo = customerNo;
+ }
+
+ public String getMatePriceJson() {
+ return matePriceJson;
+ }
+
+ public void setMatePriceJson(String matePriceJson) {
+ this.matePriceJson = matePriceJson;
+ }
+}
diff --git a/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/ErpToPosMaterialSyncRequest.java b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/ErpToPosMaterialSyncRequest.java
new file mode 100644
index 0000000..9198079
--- /dev/null
+++ b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/ErpToPosMaterialSyncRequest.java
@@ -0,0 +1,63 @@
+package com.jwsaas.api.boduo.erp.request;
+
+import com.jwsaas.api.request.AbstractRequest;
+
+import javax.validation.constraints.NotNull;
+
+/**
+ * @Author:CHL
+ * @Date:Create in 2018/4/28
+ * @Description: erp 中的数据向 pos中同步调用的接口
+ */
+public class ErpToPosMaterialSyncRequest extends AbstractRequest {
+ @NotNull
+ private String cInvCode; //物料编号
+ @NotNull
+ private String cInvName; //物料名称
+ @NotNull
+ private String cInvStd; //物料规格
+ @NotNull
+ private String cInvCCode; //分类编号
+ @NotNull
+ private String cComUnitCode; //主计量单位编码
+
+ public String getcInvCode() {
+ return cInvCode;
+ }
+
+ public void setcInvCode(String cInvCode) {
+ this.cInvCode = cInvCode;
+ }
+
+ public String getcInvName() {
+ return cInvName;
+ }
+
+ public void setcInvName(String cInvName) {
+ this.cInvName = cInvName;
+ }
+
+ public String getcInvStd() {
+ return cInvStd;
+ }
+
+ public void setcInvStd(String cInvStd) {
+ this.cInvStd = cInvStd;
+ }
+
+ public String getcInvCCode() {
+ return cInvCCode;
+ }
+
+ public void setcInvCCode(String cInvCCode) {
+ this.cInvCCode = cInvCCode;
+ }
+
+ public String getcComUnitCode() {
+ return cComUnitCode;
+ }
+
+ public void setcComUnitCode(String cComUnitCode) {
+ this.cComUnitCode = cComUnitCode;
+ }
+}
diff --git a/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/MaterialDetailRequest.java b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/MaterialDetailRequest.java
new file mode 100644
index 0000000..cee6e34
--- /dev/null
+++ b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/MaterialDetailRequest.java
@@ -0,0 +1,23 @@
+package com.jwsaas.api.boduo.erp.request;
+
+import com.jwsaas.api.request.AbstractRequest;
+
+import javax.validation.constraints.NotNull;
+
+/**
+ * @Author:CHL
+ * @Date:Create in 2018/3/22
+ * @Description: 物料信息返回对象
+ */
+public class MaterialDetailRequest extends AbstractRequest {
+ @NotNull
+ private String storeId;
+
+ public String getStoreId() {
+ return storeId;
+ }
+
+ public void setStoreId(String storeId) {
+ this.storeId = storeId;
+ }
+}
diff --git a/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/MaterialToErpSyncRequest.java b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/MaterialToErpSyncRequest.java
new file mode 100644
index 0000000..2a11a0a
--- /dev/null
+++ b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/MaterialToErpSyncRequest.java
@@ -0,0 +1,23 @@
+package com.jwsaas.api.boduo.erp.request;
+
+import com.jwsaas.api.request.AbstractRequest;
+
+import javax.validation.constraints.NotNull;
+
+/**
+ * @Author:CHL
+ * @Date:Create in 2018/4/28
+ * @Description: erp 中的数据向 pos中同步调用的接口
+ */
+public class MaterialToErpSyncRequest extends AbstractRequest {
+ @NotNull
+ private String matreialJson; //原料json
+
+ public String getMatreialJson() {
+ return matreialJson;
+ }
+
+ public void setMatreialJson(String matreialJson) {
+ this.matreialJson = matreialJson;
+ }
+}
diff --git a/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/MaterialTypeRequest.java b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/MaterialTypeRequest.java
new file mode 100644
index 0000000..41dd321
--- /dev/null
+++ b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/MaterialTypeRequest.java
@@ -0,0 +1,12 @@
+package com.jwsaas.api.boduo.erp.request;
+
+import com.jwsaas.api.request.AbstractRequest;
+
+/**
+ * @Author:CHL
+ * @Date:Create in 2018/3/23
+ * @Description: 物料分类信息返回对象
+ */
+public class MaterialTypeRequest extends AbstractRequest {
+
+}
diff --git a/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/MaterialUnitRequest.java b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/MaterialUnitRequest.java
new file mode 100644
index 0000000..29324b6
--- /dev/null
+++ b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/MaterialUnitRequest.java
@@ -0,0 +1,14 @@
+package com.jwsaas.api.boduo.erp.request;
+
+import com.jwsaas.api.request.AbstractRequest;
+
+import javax.validation.constraints.NotNull;
+
+/**
+ * @Author:CHL
+ * @Date:Create in 2018/3/23
+ * @Description: 物料单位信息返回对象
+ */
+public class MaterialUnitRequest extends AbstractRequest {
+
+}
diff --git a/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/PayMoneyTicketRequest.java b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/PayMoneyTicketRequest.java
new file mode 100644
index 0000000..572cd9b
--- /dev/null
+++ b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/PayMoneyTicketRequest.java
@@ -0,0 +1,60 @@
+package com.jwsaas.api.boduo.erp.request;
+
+import com.jwsaas.api.request.AbstractRequest;
+
+import javax.validation.constraints.NotNull;
+
+/**
+ * @Author:CHL
+ * @Date:Create in 2018/04/02
+ * @Description: 调用erp中确认扣款接口
+ */
+public class PayMoneyTicketRequest extends AbstractRequest {
+ @NotNull
+ private String askGoodsTicket;
+ @NotNull
+ private Integer isHaveT6Blance; //是否使用余额度
+ private Integer deliveryMode; //配送标识
+ private String payType; //付款方式
+ private Integer isAskGoods; //是否要货
+
+ public String getAskGoodsTicket() {
+ return askGoodsTicket;
+ }
+
+ public void setAskGoodsTicket(String askGoodsTicket) {
+ this.askGoodsTicket = askGoodsTicket;
+ }
+
+ public Integer getIsHaveT6Blance() {
+ return isHaveT6Blance;
+ }
+
+ public void setIsHaveT6Blance(Integer isHaveT6Blance) {
+ this.isHaveT6Blance = isHaveT6Blance;
+ }
+
+ public Integer getDeliveryMode() {
+ return deliveryMode;
+ }
+
+ public void setDeliveryMode(Integer deliveryMode) {
+ this.deliveryMode = deliveryMode;
+ }
+
+ public String getPayType() {
+ return payType;
+ }
+
+ public void setPayType(String payType) {
+ this.payType = payType;
+ }
+
+ public Integer getIsAskGoods() {
+ return isAskGoods;
+ }
+
+ public void setIsAskGoods(Integer isAskGoods) {
+ this.isAskGoods = isAskGoods;
+ }
+}
diff --git a/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/StoreAskMaterialSyncRequest.java b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/StoreAskMaterialSyncRequest.java
new file mode 100644
index 0000000..fd1b0a6
--- /dev/null
+++ b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/StoreAskMaterialSyncRequest.java
@@ -0,0 +1,23 @@
+package com.jwsaas.api.boduo.erp.request;
+
+import com.jwsaas.api.request.AbstractRequest;
+
+import javax.validation.constraints.NotNull;
+
+/**
+ * @Author:CHL
+ * @Date:Create in 2018/3/30
+ * @Description: erp中门店允许要货物料同步
+ */
+public class StoreAskMaterialSyncRequest extends AbstractRequest {
+ @NotNull
+ private String storeId;
+
+ public String getStoreId() {
+ return storeId;
+ }
+
+ public void setStoreId(String storeId) {
+ this.storeId = storeId;
+ }
+}
diff --git a/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/SyncMaterialRequest.java b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/SyncMaterialRequest.java
new file mode 100644
index 0000000..7adea89
--- /dev/null
+++ b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/SyncMaterialRequest.java
@@ -0,0 +1,22 @@
+package com.jwsaas.api.boduo.erp.request;
+
+import javax.validation.constraints.NotNull;
+
+import com.jwsaas.api.request.AbstractRequest;
+import com.jwsaas.open.annotation.IgnoreSign;
+
+public class SyncMaterialRequest extends AbstractRequest {
+
+ @NotNull
+ @IgnoreSign
+ private String material;// 原料JSON
+
+ public String getMaterial() {
+ return material;
+ }
+
+ public void setMaterial(String material) {
+ this.material = material;
+ }
+
+}
diff --git a/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/SyncMaterialTypeRequest.java b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/SyncMaterialTypeRequest.java
new file mode 100644
index 0000000..bb87118
--- /dev/null
+++ b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/SyncMaterialTypeRequest.java
@@ -0,0 +1,22 @@
+package com.jwsaas.api.boduo.erp.request;
+
+import javax.validation.constraints.NotNull;
+
+import com.jwsaas.api.request.AbstractRequest;
+import com.jwsaas.open.annotation.IgnoreSign;
+
+public class SyncMaterialTypeRequest extends AbstractRequest {
+
+ @NotNull
+ @IgnoreSign
+ private String materialType;// 原料分类JSON
+
+ public String getMaterialType() {
+ return materialType;
+ }
+
+ public void setMaterialType(String materialType) {
+ this.materialType = materialType;
+ }
+
+}
diff --git a/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/SyncMaterialUnitRequest.java b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/SyncMaterialUnitRequest.java
new file mode 100644
index 0000000..8624e56
--- /dev/null
+++ b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/SyncMaterialUnitRequest.java
@@ -0,0 +1,22 @@
+package com.jwsaas.api.boduo.erp.request;
+
+import javax.validation.constraints.NotNull;
+
+import com.jwsaas.api.request.AbstractRequest;
+import com.jwsaas.open.annotation.IgnoreSign;
+
+public class SyncMaterialUnitRequest extends AbstractRequest {
+
+ @NotNull
+ @IgnoreSign
+ private String materialUnit;// 原料单位JSON
+
+ public String getMaterialUnit() {
+ return materialUnit;
+ }
+
+ public void setMaterialUnit(String materialUnit) {
+ this.materialUnit = materialUnit;
+ }
+
+}
diff --git a/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/V1PosDishToV2Request.java b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/V1PosDishToV2Request.java
new file mode 100644
index 0000000..c0a914e
--- /dev/null
+++ b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/request/V1PosDishToV2Request.java
@@ -0,0 +1,33 @@
+package com.jwsaas.api.boduo.erp.request;
+
+import com.jwsaas.api.request.AbstractRequest;
+
+import javax.validation.constraints.NotNull;
+
+/**
+ * @Author:CHL
+ * @Date:Create in 2018/5/16
+ * @Description:v1系统的数据向v2数据对象
+ */
+public class V1PosDishToV2Request extends AbstractRequest {
+ @NotNull
+ private String storeNos; //升级的门店编号
+ @NotNull
+ private String v1TenantId; //v1门店编号
+
+ public String getStoreNos() {
+ return storeNos;
+ }
+
+ public void setStoreNos(String storeNos) {
+ this.storeNos = storeNos;
+ }
+
+ public String getV1TenantId() {
+ return v1TenantId;
+ }
+
+ public void setV1TenantId(String v1TenantId) {
+ this.v1TenantId = v1TenantId;
+ }
+}
diff --git a/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/response/AskTicketMoneyListResponse.java b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/response/AskTicketMoneyListResponse.java
new file mode 100644
index 0000000..e78c2f8
--- /dev/null
+++ b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/response/AskTicketMoneyListResponse.java
@@ -0,0 +1,117 @@
+package com.jwsaas.api.boduo.erp.response;
+
+/**
+ * @Author:CHL
+ * @Date:Create in 2018/04/02
+ * @Description: 在erp中获取要货单金额 返回数据
+ */
+public class AskTicketMoneyListResponse {
+ private int status;
+ private String message;
+ private String errCode;
+ private String errMessage;
+ private Double sumMaterialMoney; //原料金额
+ private Double storeBalance; // 账户余额
+ private Double storeRebate; //返利
+ private Double useRebate; //能用的返利
+ private Double usualFreight; //常温运费
+ private Double coldFreight; //冷链运费
+ private Double askSumMoney; //要货总金额
+ private String description; // 备注
+
+ public int getStatus() {
+ return status;
+ }
+
+ public void setStatus(int status) {
+ this.status = status;
+ }
+
+ public String getMessage() {
+ return message;
+ }
+
+ public void setMessage(String message) {
+ this.message = message;
+ }
+
+ public String getErrCode() {
+ return errCode;
+ }
+
+ public void setErrCode(String errCode) {
+ this.errCode = errCode;
+ }
+
+ public String getErrMessage() {
+ return errMessage;
+ }
+
+ public void setErrMessage(String errMessage) {
+ this.errMessage = errMessage;
+ }
+
+ public Double getSumMaterialMoney() {
+ return sumMaterialMoney;
+ }
+
+ public void setSumMaterialMoney(Double sumMaterialMoney) {
+ this.sumMaterialMoney = sumMaterialMoney;
+ }
+
+ public Double getStoreBalance() {
+ return storeBalance;
+ }
+
+ public void setStoreBalance(Double storeBalance) {
+ this.storeBalance = storeBalance;
+ }
+
+ public Double getStoreRebate() {
+ return storeRebate;
+ }
+
+ public void setStoreRebate(Double storeRebate) {
+ this.storeRebate = storeRebate;
+ }
+
+ public Double getUseRebate() {
+ return useRebate;
+ }
+
+ public void setUseRebate(Double useRebate) {
+ this.useRebate = useRebate;
+ }
+
+ public Double getUsualFreight() {
+ return usualFreight;
+ }
+
+ public void setUsualFreight(Double usualFreight) {
+ this.usualFreight = usualFreight;
+ }
+
+ public Double getColdFreight() {
+ return coldFreight;
+ }
+
+ public void setColdFreight(Double coldFreight) {
+ this.coldFreight = coldFreight;
+ }
+
+ public Double getAskSumMoney() {
+ return askSumMoney;
+ }
+
+ public void setAskSumMoney(Double askSumMoney) {
+ this.askSumMoney = askSumMoney;
+ }
+
+ public String getDescription() {
+ return description;
+ }
+
+ public void setDescription(String description) {
+ this.description = description;
+ }
+}
diff --git a/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/response/DeliveryModeListResponse.java b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/response/DeliveryModeListResponse.java
new file mode 100644
index 0000000..57ceace
--- /dev/null
+++ b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/response/DeliveryModeListResponse.java
@@ -0,0 +1,58 @@
+package com.jwsaas.api.boduo.erp.response;
+
+import com.alibaba.fastjson.JSONArray;
+
+/**
+ * @Author:CHL
+ * @Date:Create in 2018/3/23
+ * @Description: 原料信息
+ */
+public class DeliveryModeListResponse {
+ private int status;
+
+ private String message;
+
+ private String errCode;
+
+ private String errMessage;
+ private JSONArray list; //配送方式集合
+
+ public int getStatus() {
+ return status;
+ }
+
+ public void setStatus(int status) {
+ this.status = status;
+ }
+
+ public String getMessage() {
+ return message;
+ }
+
+ public void setMessage(String message) {
+ this.message = message;
+ }
+
+ public String getErrCode() {
+ return errCode;
+ }
+
+ public void setErrCode(String errCode) {
+ this.errCode = errCode;
+ }
+
+ public String getErrMessage() {
+ return errMessage;
+ }
+
+ public void setErrMessage(String errMessage) {
+ this.errMessage = errMessage;
+ }
+ public JSONArray getList() {
+ return list;
+ }
+
+ public void setList(JSONArray list) {
+ this.list = list;
+ }
+}
diff --git a/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/response/MaterialDetailResponse.java b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/response/MaterialDetailResponse.java
new file mode 100644
index 0000000..0c8f359
--- /dev/null
+++ b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/response/MaterialDetailResponse.java
@@ -0,0 +1,57 @@
+package com.jwsaas.api.boduo.erp.response;
+
+/**
+ * @Author:CHL
+ * @Date:Create in 2018/3/23
+ * @Description: 原料信息
+ */
+public class MaterialDetailResponse {
+ private int status;
+
+ private String message;
+
+ private String errCode;
+
+ private String errMessage;
+ private Integer count; //返回的执行记录数
+
+ public int getStatus() {
+ return status;
+ }
+
+ public void setStatus(int status) {
+ this.status = status;
+ }
+
+ public String getMessage() {
+ return message;
+ }
+
+ public void setMessage(String message) {
+ this.message = message;
+ }
+
+ public String getErrCode() {
+ return errCode;
+ }
+
+ public void setErrCode(String errCode) {
+ this.errCode = errCode;
+ }
+
+ public String getErrMessage() {
+ return errMessage;
+ }
+
+ public void setErrMessage(String errMessage) {
+ this.errMessage = errMessage;
+ }
+
+ public Integer getCount() {
+ return count;
+ }
+
+ public void setCount(Integer count) {
+ this.count = count;
+ }
+}
diff --git a/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/response/MaterialTypeResponse.java b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/response/MaterialTypeResponse.java
new file mode 100644
index 0000000..065b6ee
--- /dev/null
+++ b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/response/MaterialTypeResponse.java
@@ -0,0 +1,57 @@
+package com.jwsaas.api.boduo.erp.response;
+
+/**
+ * @Author:CHL
+ * @Date:Create in 2018/3/23
+ * @Description: 原料数据类型
+ */
+public class MaterialTypeResponse {
+ private int status;
+
+ private String message;
+
+ private String errCode;
+
+ private String errMessage;
+ private Integer count; //返回的执行记录数
+
+ public int getStatus() {
+ return status;
+ }
+
+ public void setStatus(int status) {
+ this.status = status;
+ }
+
+ public String getMessage() {
+ return message;
+ }
+
+ public void setMessage(String message) {
+ this.message = message;
+ }
+
+ public String getErrCode() {
+ return errCode;
+ }
+
+ public void setErrCode(String errCode) {
+ this.errCode = errCode;
+ }
+
+ public String getErrMessage() {
+ return errMessage;
+ }
+
+ public void setErrMessage(String errMessage) {
+ this.errMessage = errMessage;
+ }
+
+ public Integer getCount() {
+ return count;
+ }
+
+ public void setCount(Integer count) {
+ this.count = count;
+ }
+}
diff --git a/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/response/MaterialUnitResponse.java b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/response/MaterialUnitResponse.java
new file mode 100644
index 0000000..f9c8e39
--- /dev/null
+++ b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/response/MaterialUnitResponse.java
@@ -0,0 +1,57 @@
+package com.jwsaas.api.boduo.erp.response;
+
+/**
+ * @Author:CHL
+ * @Date:Create in 2018/3/23
+ * @Description:
+ */
+public class MaterialUnitResponse {
+ private int status;
+
+ private String message;
+
+ private String errCode;
+
+ private String errMessage;
+ private Integer count; //返回的执行记录数
+
+ public int getStatus() {
+ return status;
+ }
+
+ public void setStatus(int status) {
+ this.status = status;
+ }
+
+ public String getMessage() {
+ return message;
+ }
+
+ public void setMessage(String message) {
+ this.message = message;
+ }
+
+ public String getErrCode() {
+ return errCode;
+ }
+
+ public void setErrCode(String errCode) {
+ this.errCode = errCode;
+ }
+
+ public String getErrMessage() {
+ return errMessage;
+ }
+
+ public void setErrMessage(String errMessage) {
+ this.errMessage = errMessage;
+ }
+
+ public Integer getCount() {
+ return count;
+ }
+
+ public void setCount(Integer count) {
+ this.count = count;
+ }
+}
diff --git a/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/response/PayMoneyTicketResponse.java b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/response/PayMoneyTicketResponse.java
new file mode 100644
index 0000000..3c30c81
--- /dev/null
+++ b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/response/PayMoneyTicketResponse.java
@@ -0,0 +1,54 @@
+package com.jwsaas.api.boduo.erp.response;
+
+/**
+ * @Author:CHL
+ * @Date:Create in 2018/04/02
+ * @Description: 在erp中确认扣款 返回数据
+ */
+public class PayMoneyTicketResponse {
+ private String status;
+ private String message;
+ private Double storeBalance; //账户余额
+ private Double storeRebate; // 返利金额
+ private Double payMoney; //要货扣除的金额
+
+ public String getStatus() {
+ return status;
+ }
+
+ public void setStatus(String status) {
+ this.status = status;
+ }
+
+ public String getMessage() {
+ return message;
+ }
+
+ public void setMessage(String message) {
+ this.message = message;
+ }
+
+ public Double getStoreBalance() {
+ return storeBalance;
+ }
+
+ public void setStoreBalance(Double storeBalance) {
+ this.storeBalance = storeBalance;
+ }
+
+ public Double getStoreRebate() {
+ return storeRebate;
+ }
+
+ public void setStoreRebate(Double storeRebate) {
+ this.storeRebate = storeRebate;
+ }
+
+ public Double getPayMoney() {
+ return payMoney;
+ }
+
+ public void setPayMoney(Double payMoney) {
+ this.payMoney = payMoney;
+ }
+}
diff --git a/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/response/StoreAskMaterialSyncResponse.java b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/response/StoreAskMaterialSyncResponse.java
new file mode 100644
index 0000000..113b68a
--- /dev/null
+++ b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/response/StoreAskMaterialSyncResponse.java
@@ -0,0 +1,57 @@
+package com.jwsaas.api.boduo.erp.response;
+
+/**
+ * @Author:CHL
+ * @Date:Create in 2018/3/23
+ * @Description:
+ */
+public class StoreAskMaterialSyncResponse {
+ private int status;
+
+ private String message;
+
+ private String errCode;
+
+ private String errMessage;
+ private Integer count; //返回的执行记录数
+
+ public int getStatus() {
+ return status;
+ }
+
+ public void setStatus(int status) {
+ this.status = status;
+ }
+
+ public String getMessage() {
+ return message;
+ }
+
+ public void setMessage(String message) {
+ this.message = message;
+ }
+
+ public String getErrCode() {
+ return errCode;
+ }
+
+ public void setErrCode(String errCode) {
+ this.errCode = errCode;
+ }
+
+ public String getErrMessage() {
+ return errMessage;
+ }
+
+ public void setErrMessage(String errMessage) {
+ this.errMessage = errMessage;
+ }
+
+ public Integer getCount() {
+ return count;
+ }
+
+ public void setCount(Integer count) {
+ this.count = count;
+ }
+}
diff --git a/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/service/AskGoodsTicketErpService.java b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/service/AskGoodsTicketErpService.java
new file mode 100644
index 0000000..7210090
--- /dev/null
+++ b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/service/AskGoodsTicketErpService.java
@@ -0,0 +1,34 @@
+package com.jwsaas.api.boduo.erp.service;
+
+import com.jwsaas.api.boduo.erp.request.AskTicketMoneyListRequest;
+import com.jwsaas.api.boduo.erp.request.CreateDispatchTicketRequest;
+import com.jwsaas.api.boduo.erp.request.PayMoneyTicketRequest;
+import com.jwsaas.api.service.WopService;
+
+/**
+ * @Author:CHL
+ * @Date:Create in 2018/3/30
+ * @Description: 获取erp要货单接口功能
+ */
+public interface AskGoodsTicketErpService extends WopService {
+ /**
+ * 查获erp中要货单扣款信息
+ * @param request
+ * @return
+ */
+ Object getErpAskTicketMoneyList(AskTicketMoneyListRequest request);
+
+ /***
+ * 为此要货单买单,执行扣款
+ * @param request
+ * @return
+ */
+ Object doErpPayMoneyTicket(PayMoneyTicketRequest request);
+
+ /**
+ * 定制erp对接要货接口;
+ * @param request
+ * @return
+ */
+ Object createDispatchTicket(CreateDispatchTicketRequest request);
+}
diff --git a/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/service/DeliveryModeListService.java b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/service/DeliveryModeListService.java
new file mode 100644
index 0000000..d88b2c4
--- /dev/null
+++ b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/service/DeliveryModeListService.java
@@ -0,0 +1,13 @@
+package com.jwsaas.api.boduo.erp.service;
+
+import com.jwsaas.api.boduo.erp.request.DeliveryModeListRequest;
+import com.jwsaas.api.service.WopService;
+
+/**
+ * @Author:CHL
+ * @Date:Create in 2018/3/30
+ * @Description: 获取erp中配送方式
+ */
+public interface DeliveryModeListService extends WopService {
+ Object getDeliveryModeList(DeliveryModeListRequest request);
+}
diff --git a/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/service/ErpToPosDataService.java b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/service/ErpToPosDataService.java
new file mode 100644
index 0000000..25d9ef1
--- /dev/null
+++ b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/service/ErpToPosDataService.java
@@ -0,0 +1,14 @@
+package com.jwsaas.api.boduo.erp.service;
+
+import com.jwsaas.api.boduo.erp.request.ErpToPosMaterialSyncRequest;
+import com.jwsaas.api.service.WopService;
+
+/**
+ * @Author:CHL
+ * @Date:Create in 2018/4/28
+ * @Description: erp 中的数据向 pos中同步调用的接口
+ */
+public interface ErpToPosDataService extends WopService {
+
+ Object saveMaterialDetail(ErpToPosMaterialSyncRequest request);
+}
diff --git a/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/service/MaterialDetailService.java b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/service/MaterialDetailService.java
new file mode 100644
index 0000000..6611654
--- /dev/null
+++ b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/service/MaterialDetailService.java
@@ -0,0 +1,21 @@
+package com.jwsaas.api.boduo.erp.service;
+
+import com.jwsaas.api.boduo.erp.request.MaterialDetailRequest;
+import com.jwsaas.api.boduo.erp.request.SyncMaterialRequest;
+import com.jwsaas.api.service.WopService;
+
+/**
+ * @Author:CHL
+ * @Date:Create in 2018/3/22
+ * @Description: 获取物料信息
+ */
+public interface MaterialDetailService extends WopService {
+ Object getMaterialDetailTea(MaterialDetailRequest request);
+
+ /**
+ * ERP同步原料资料
+ * @param request
+ * @return
+ */
+ Object syncMaterial(SyncMaterialRequest request);
+}
diff --git a/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/service/MaterialTypeService.java b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/service/MaterialTypeService.java
new file mode 100644
index 0000000..2e0270f
--- /dev/null
+++ b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/service/MaterialTypeService.java
@@ -0,0 +1,22 @@
+package com.jwsaas.api.boduo.erp.service;
+
+import com.jwsaas.api.boduo.erp.request.MaterialTypeRequest;
+import com.jwsaas.api.boduo.erp.request.SyncMaterialTypeRequest;
+import com.jwsaas.api.service.WopService;
+
+/**
+ * @Author:CHL
+ * @Date:Create in 2018/3/23
+ * @Description: 从erp中获取物料分类
+ */
+public interface MaterialTypeService extends WopService {
+
+ Object getMaterialTypeTea(MaterialTypeRequest request);
+
+ /**
+ * ERP同步原料分类
+ * @param request
+ * @return
+ */
+ Object syncMaterialType(SyncMaterialTypeRequest request);
+}
diff --git a/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/service/MaterialUnitService.java b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/service/MaterialUnitService.java
new file mode 100644
index 0000000..348a1db
--- /dev/null
+++ b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/service/MaterialUnitService.java
@@ -0,0 +1,24 @@
+package com.jwsaas.api.boduo.erp.service;
+
+import com.jwsaas.api.boduo.erp.request.MaterialUnitRequest;
+import com.jwsaas.api.boduo.erp.request.SyncMaterialUnitRequest;
+import com.jwsaas.api.service.WopService;
+
+/**
+ * @Author:CHL
+ * @Date:Create in 2018/3/23
+ * @Description: 从erp中获取物料单位
+ */
+public interface MaterialUnitService extends WopService {
+
+ Object getMaterialUnitTea(MaterialUnitRequest request);
+
+
+
+ /**
+ * ERP同步原料单位
+ * @param request
+ * @return
+ */
+ Object syncMaterialUnit(SyncMaterialUnitRequest request);
+}
diff --git a/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/service/PosToErpDataService.java b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/service/PosToErpDataService.java
new file mode 100644
index 0000000..e1dbfb8
--- /dev/null
+++ b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/service/PosToErpDataService.java
@@ -0,0 +1,71 @@
+package com.jwsaas.api.boduo.erp.service;
+
+import com.jwsaas.api.boduo.erp.request.DishToErpSyncRequest;
+import com.jwsaas.api.boduo.erp.request.ErpProductRatioRequest;
+import com.jwsaas.api.boduo.erp.request.ErpProductRequest;
+import com.jwsaas.api.boduo.erp.request.ErpProductSpecRequest;
+import com.jwsaas.api.boduo.erp.request.MaterialToErpSyncRequest;
+import com.jwsaas.api.request.product.ProductRatioRequest;
+import com.jwsaas.api.request.product.ProductRequest;
+import com.jwsaas.api.request.product.ProductSpecRequest;
+import com.jwsaas.api.service.WopService;
+
+/**
+ * @Author:CHL
+ * @Date:Create in 2018/4/28
+ * @Description: pos中的数据向 erp 中同步调用的接口
+ */
+public interface PosToErpDataService extends WopService {
+
+ Object saveDishSyncErpDetail(DishToErpSyncRequest request);
+ Object saveMaterialSyncErpDetail(MaterialToErpSyncRequest request);
+
+
+// /**
+// * 原料资料
+// *
+// * @param request
+// * @return
+// */
+// Object erpProductList(ErpProductRequest request);
+//
+// /**
+// * 原料规格资料
+// *
+// * @param request
+// * @return
+// */
+// Object erpProductSpec(ErpProductSpecRequest request);
+//
+// /**
+// * 原料库存系数
+// *
+// * @param request
+// * @return
+// */
+// Object erpProductRatio(ErpProductRatioRequest request);
+
+ /**
+ * 商品资料
+ *
+ * @param request
+ * @return
+ */
+ Object boduoProductList(ProductRequest request);
+
+ /**
+ * 商品规格资料
+ *
+ * @param request
+ * @return
+ */
+ Object boduoProductSpec(ProductSpecRequest request);
+
+ /**
+ * 商品套菜明细资料
+ *
+ * @param request
+ * @return
+ */
+ Object boduoProductRatio(ProductRatioRequest request);
+}
diff --git a/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/service/StoreAskMaterialSyncService.java b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/service/StoreAskMaterialSyncService.java
new file mode 100644
index 0000000..a04e1b7
--- /dev/null
+++ b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/service/StoreAskMaterialSyncService.java
@@ -0,0 +1,15 @@
+package com.jwsaas.api.boduo.erp.service;
+
+import com.jwsaas.api.boduo.erp.request.ErpStoreAskMaterialRequest;
+import com.jwsaas.api.boduo.erp.request.StoreAskMaterialSyncRequest;
+import com.jwsaas.api.service.WopService;
+
+/**
+ * @Author:CHL
+ * @Date:Create in 2018/3/30
+ * @Description: 从erp中获取门店允许要货的原料信息
+ */
+public interface StoreAskMaterialSyncService extends WopService {
+ Object getAskMaterialSync(StoreAskMaterialSyncRequest request);
+ Object getErpStoreAskMaterial(ErpStoreAskMaterialRequest request);
+}
diff --git a/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/service/V1PosToV2PosDataService.java b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/service/V1PosToV2PosDataService.java
new file mode 100644
index 0000000..4abb4a6
--- /dev/null
+++ b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/service/V1PosToV2PosDataService.java
@@ -0,0 +1,14 @@
+package com.jwsaas.api.boduo.erp.service;
+
+import com.jwsaas.api.boduo.erp.request.V1PosDishToV2Request;
+import com.jwsaas.api.service.WopService;
+
+/**
+ * @Author:CHL
+ * @Date:Create in 2018/05/16
+ * @Description: v1系统的数据向v2一次性同步接口
+ */
+public interface V1PosToV2PosDataService extends WopService {
+
+ Object saveV1PosDishToV2Detail(V1PosDishToV2Request request);
+}
diff --git a/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/service/impl/AskGoodsTicketErpServiceImpl.java b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/service/impl/AskGoodsTicketErpServiceImpl.java
new file mode 100644
index 0000000..5f46bc8
--- /dev/null
+++ b/food-open/food-open-api/src/main/java/com/jwsaas/api/boduo/erp/service/impl/AskGoodsTicketErpServiceImpl.java
@@ -0,0 +1,601 @@
+package com.jwsaas.api.boduo.erp.service.impl;
+
+import com.alibaba.fastjson.JSON;
+import com.alibaba.fastjson.JSONArray;
+import com.alibaba.fastjson.JSONObject;
+import com.jwsaas.api.boduo.erp.request.AskTicketMoneyListRequest;
+import com.jwsaas.api.boduo.erp.request.CreateDispatchTicketRequest;
+import com.jwsaas.api.boduo.erp.request.PayMoneyTicketRequest;
+import com.jwsaas.api.boduo.erp.service.AskGoodsTicketErpService;
+import com.jwsaas.api.entity.pos.MaterialInfo;
+import com.jwsaas.api.response.mode.CommonDataResponse;
+import com.jwsaas.api.service.impl.ErpBaseServiceImpl;
+import com.jwsaas.bean.AppKeyInfo;
+import com.jwsaas.cache.data.ProductUnitCache;
+import com.jwsaas.condition.Criteria;
+import com.jwsaas.condition.Restrictions;
+import com.jwsaas.entity.food.*;
+import com.jwsaas.http.HttpTool;
+import com.jwsaas.open.annotation.HttpAction;
+import com.jwsaas.open.annotation.NeedInSessionType;
+import com.jwsaas.open.annotation.ServiceMethod;
+import com.jwsaas.open.annotation.ServiceMethodBean;
+import com.jwsaas.open.response.BusinessServiceErrorResponse;
+import com.jwsaas.service.food.*;
+import com.jwsaas.utils.AppKeyUtil;
+import com.jwsaas.utils.DateUtils;
+import com.jwsaas.utils.PropertiesUtil;
+import org.apache.commons.collections4.CollectionUtils;
+import org.apache.commons.lang3.StringUtils;
+import org.apache.http.HttpResponse;
+
+import javax.annotation.Resource;
+import java.util.*;
+
+/**
+ * @Author:CHL
+ * @Date:Create in 2018/3/30
+ * @Description:获取erp要货单接口功能
+ */
+
+@ServiceMethodBean(version = "1.0")
+public class AskGoodsTicketErpServiceImpl extends ErpBaseServiceImpl implements AskGoodsTicketErpService {
+ private static final long serialVersionUID = -345096567692034978L;
+ @Resource
+ private com.jwsaas.service.food.AskGoodsTicketService askGoodsTicketService;
+ @Resource
+ private com.jwsaas.service.food.AskGoodsDetailService askGoodsDetailService;
+ @Resource
+ private com.jwsaas.service.food.StoreService storeService;
+ @Resource
+ private com.jwsaas.service.food.ProductUnitService productUnitService;
+ @Resource
+ private DispatchTicketService dispatchTicketService;
+ @Resource
+ private ProductRatioService productRatioService;
+ @Resource
+ private ProductSpecService productSpecService;
+ @Resource
+ private StorageService storageService;
+ @Resource
+ private ProductUnitCache productUnitCache;
+
+
+
+ @ServiceMethod(method = "erp.trial.operation.money", httpAction = HttpAction.POST, needInSession = NeedInSessionType.NO, title = "查获erp中要货单扣款信息")
+ @Override
+ public Object getErpAskTicketMoneyList(AskTicketMoneyListRequest request) {
+ String appKey = request.getWopRequestContext().getAppKey();
+ logger.debug("appKey=" + appKey);
+ AppKeyInfo appKeyInfo = AppKeyUtil.decode(appKey);
+ String tenantCode = appKeyInfo.getTenantCode();
+ String tenantId = tenantCode;
+ String ticketId = request.getTicketId();
+ String info = "erp.ask.ticket.modey.list-->getErpAskTicketMoneyList 接口从erp中要货单扣款信息";
+ logger.info(info+"企业号:{}",tenantId);
+ CommonDataResponse response = null;
+// AskTicketMoneyListResponse response = null;
+ try {
+// response = new AskTicketMoneyListResponse();
+ response = new CommonDataResponse();
+ AskGoodsTicket ticket = this.askGoodsTicketService.get(tenantId,ticketId);
+
+ String deliveryMode = ticket.getDeliveryMode(); //配送方式
+ String storeId = ticket.getStoreId(); //门店ID
+
+ if(ticket == null){
+ response.setErrCode("error");
+ response.setMessage("获取要货单信息不存在,审核失败");
+ return response;
+ }
+ /* if(ticket.getErpToExamine()!=null && ticket.getErpToExamine()==1){
+ response.setErrCode("error");
+ response.setMessage("要获单已在erp中存在,请作废该单据重新要货");
+ return response;
+ }*/
+ if(ticket.getStatus() == 3 || ticket.getStatus()==4 ){
+ response.setErrCode("error");
+ response.setMessage("要货单为配送状态或者为已收货状态,请重新生成要货单");
+ return response;
+ }
+ Store dbs = this.storeService.get(tenantId,storeId);
+
+ String storeNo=dbs.getExt1();
+ if(StringUtils.isEmpty(storeNo)){
+ response.setErrCode("error");
+ response.setMessage("门店属性扩展信息没有设置,请在后台设置对应erp中的客户编号");
+ }
+ ticket.setStoreNo(storeNo);
+ List agdList = this.askGoodsDetailService.findList(tenantId,"ticketId",ticketId);
+
+ // 开放接口签名
+ Map paramMap = new HashMap<>(20);
+ List ignoreSignParams = new ArrayList();
+ // 系统级参数
+ paramMap.put("appKey", PropertiesUtil.getValue(fileName, "open.api.appKey")); //开发者必须事先通过申请获取appKey/secret后,才能进行应用的开发
+ paramMap.put("method", "common.returnChargeConfirmInfo"); //方法名称
+ paramMap.put("v", PropertiesUtil.getValue(fileName, "open.api.version")); //服务方法的版本号
+ paramMap.put("format", PropertiesUtil.getValue(fileName, "open.api.format"));//报文的格式,支持XML和JSON,默认JSON
+ paramMap.put("locale", PropertiesUtil.getValue(fileName, "open.api.locale")); //本地化类型,默认zh_CN
+ paramMap.put("timestamp", String.valueOf(System.currentTimeMillis()));//时间戳,自1970-01-01 00:00:00.000起的毫秒数
+ paramMap.put("client", PropertiesUtil.getValue(fileName, "open.api.client"));//客户端类型
+ // 业务参数
+
+ String askgoodsJson = buildAskGoodsTicket(ticket);
+ String askgoodDetailJson = buildAskGoodsDetail(tenantId,agdList);
+ paramMap.put("goodsJson",askgoodsJson);
+ paramMap.put("goodsDetailsJson",askgoodDetailJson);
+ paramMap.put("deliveryMode",deliveryMode);
+ // 参数签名
+ String signValue = this.sign(paramMap, ignoreSignParams,PropertiesUtil.getValue(fileName,"open.api.secret"));
+ paramMap.put("sign",signValue); //签名串,请求参数的签名,服务平台通过它验证请求数据的合法性
+ String url=PropertiesUtil.getValue(fileName,"open.api.url");
+ long startTime = System.currentTimeMillis();
+ final HttpResponse hr = HttpTool.url(url).form(paramMap).post();
+ long endTime = System.currentTimeMillis();
+ logger.info("执行时间:{}",endTime-startTime);
+ final String content = HttpTool.getResponseAsString(hr);
+
+ logger.debug("调用erp接口 common.returnChargeConfirmInfo 返回的数据如下:{}",content);
+
+ if(this.isSuccessful(content)){
+ JSONObject object = JSON.parseObject(content);
+ String state = object.getString("state");
+ if(StringUtils.equals("1",state)){
+ Double sumMaterialMoney = Double.parseDouble(object.get("sumMaterialMoney")+""); //原料金额
+ Double storeBalance= Double.parseDouble(object.get("storeBalance")+""); // 账户余额
+ Double storeRebate= Double.parseDouble(object.get("storeRebate")+""); //返利
+ Double useRebate= Double.parseDouble(object.get("useRebate")+""); //能用的返利
+ Double usualFreight= Double.parseDouble(object.get("usualFreight")+""); //常温运费
+ Double coldFreight= Double.parseDouble(object.get("coldFreight")+""); //冷链运费
+ Double askSumMoney= Double.parseDouble(object.get("askSumMoney")+""); //要货总金额
+ String description= object.get("message")+""; // 备注
+
+ Map data = new HashMap<>();
+ data.put("sumMaterialMoney",sumMaterialMoney);
+ data.put("storeBalance",storeBalance);
+ data.put("storeRebate",storeRebate);
+ data.put("useRebate",useRebate);
+ data.put("usualFreight",usualFreight);
+ data.put("coldFreight",coldFreight);
+ data.put("askSumMoney",askSumMoney);
+ data.put("description",description);
+ response.setStatus(1);
+ response.setMessage("获取数据成功" + description);
+ response.setData(data);
+ //更新调用过erp接口后 单据的标识
+ ticket.setErpToExamine(1);
+ this.askGoodsTicketService.update(tenantId,ticket);
+ }else{
+ String description= object.get("message")+""; // 备注
+ response.setErrCode("error");
+ response.setMessage("调用erp接口失败,接口返回信息:" + description);
+ logger.info(content);
+ }
+
+ }else{
+ response.setErrCode("error");
+ response.setMessage("操作失败");
+ }
+ } catch (Exception e) {
+ e.printStackTrace();
+ logger.error(info + ",发生异常", e);
+ return new BusinessServiceErrorResponse(request.getWopRequestContext(), "COMMON_ERROR", request.getWopRequestContext().getLocale());
+ }
+ return response;
+ }
+ /**
+ * 构建erp中要货单的明细信息
+ * @param agdList
+ * @return
+ */
+ private String buildAskGoodsDetail(String tenantId,List agdList) throws Exception {
+ List