Compare commits
	
		
			55 Commits
		
	
	
		
			ncore-samp
			...
			ncore-samp
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 7f6f36dc03 | |||
| 4ad2e24359 | |||
| 4f101e8e1b | |||
| ffb46698b2 | |||
| 95cf204c5b | |||
| b7e72931af | |||
| 2af8ff9473 | |||
| 7faa0a80c8 | |||
| d7612d94ab | |||
| bb2c8502c5 | |||
| ef032b8181 | |||
| 134997c7f9 | |||
| a669f6e28c | |||
| 5643ab1ea3 | |||
| fc1341cd44 | |||
| 0d9b0c13e9 | |||
| 06dbb72bd4 | |||
| 44cc49aa64 | |||
| e642ed9ad5 | |||
| 63f268495e | |||
| 667ee2208c | |||
| e6649123d5 | |||
| 637ffda0ab | |||
| dd66fb03db | |||
| f61c15b1da | |||
| 302367c667 | |||
| bb80491ae0 | |||
| 1e17d4102e | |||
| 5edc366eb5 | |||
| cbf9d5c2ed | |||
| 432ec83acd | |||
| 60b666f9d5 | |||
| 864508a236 | |||
| e76924ac17 | |||
| 769c884f46 | |||
| 2703daa196 | |||
| 1b4a24aef3 | |||
| 0d0a15a159 | |||
| 4f0adb6a17 | |||
| 3c14c91c61 | |||
| 986a0c8a6c | |||
| d1d294ba6f | |||
| 84ba9b9f60 | |||
| 1e57c6fbcf | |||
| 19e47726c9 | |||
| 41afcd70ef | |||
| af2d6bb049 | |||
| 842155d887 | |||
| a242fe86ff | |||
| 4300f62951 | |||
| 861c6af76a | |||
| cd4cc614a6 | |||
| 2481138e00 | |||
| 43bce7ea55 | |||
| af224f8795 | 
							
								
								
									
										80
									
								
								.gitattributes
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										80
									
								
								.gitattributes
									
									
									
									
										vendored
									
									
								
							| @ -1 +1,79 @@ | |||||||
| *.bat text eol=crlf | # Explicitly declare text=auto files you want to always be normalized and converted | ||||||
|  | # to native line endings on checkout. | ||||||
|  | * text=auto | ||||||
|  | *.txt text | ||||||
|  | *.log text | ||||||
|  | *.sql text | ||||||
|  | *.template text | ||||||
|  | *.properties text | ||||||
|  | *.rc text | ||||||
|  | *.ini text | ||||||
|  | *.tpl text | ||||||
|  | *.cfg text | ||||||
|  | *.bat text | ||||||
|  | *.cmd text | ||||||
|  | *.iss text | ||||||
|  | *.ipr text | ||||||
|  | *.iml text | ||||||
|  | *.iws text | ||||||
|  | *.java text | ||||||
|  | *.jj text | ||||||
|  | *.cup text | ||||||
|  | *.pl text | ||||||
|  | *.pas text | ||||||
|  | *.pp text | ||||||
|  | *.inc text | ||||||
|  | *.dpk text | ||||||
|  | *.bpk text | ||||||
|  | *.dfm text | ||||||
|  | *.xfm text | ||||||
|  | *.lfm text | ||||||
|  | *.dpr text | ||||||
|  | *.bpr text | ||||||
|  | *.bpg text | ||||||
|  | *.lpr text | ||||||
|  | *.lrs text | ||||||
|  | *.frc text | ||||||
|  | *.lpk text | ||||||
|  | *.lpi text | ||||||
|  | *.dproj text | ||||||
|  | *.bdsproj text | ||||||
|  | *.bdsgroup text | ||||||
|  | *.groupproj text | ||||||
|  | *.cbproj text | ||||||
|  | *.dof text | ||||||
|  | *.cpp text | ||||||
|  | *.c text | ||||||
|  | *.h text | ||||||
|  | *.awk text | ||||||
|  | *.sh text eol=lf | ||||||
|  | *.csv text | ||||||
|  | *.url text | ||||||
|  | *.tld text | ||||||
|  | *.xml text | ||||||
|  | *.xsl text | ||||||
|  | *.xsd text | ||||||
|  | *.jrxml text | ||||||
|  | *.dtd text | ||||||
|  | *.js  text | ||||||
|  | *.json  text | ||||||
|  | *.css text | ||||||
|  | *.jsp text | ||||||
|  | *.htm text | ||||||
|  | *.html text | ||||||
|  | *.rtx text | ||||||
|  | *.tsv text | ||||||
|  | *.etx text | ||||||
|  | *.sgm text | ||||||
|  | *.sgml text | ||||||
|  | *.talk text | ||||||
|  | *.vcf text | ||||||
|  | makefile text eol=lf | ||||||
|  | COPYING text | ||||||
|  | .gitattributes text | ||||||
|  | .gitignore text | ||||||
|  | *.gradle text | ||||||
|  | .*src text | ||||||
|  | *.stg text | ||||||
|  | *.g text | ||||||
|  | *. eol=lf | ||||||
|  | |||||||
							
								
								
									
										96
									
								
								build.gradle
									
									
									
									
									
								
							
							
						
						
									
										96
									
								
								build.gradle
									
									
									
									
									
								
							| @ -1,21 +1,14 @@ | |||||||
| buildscript { | plugins { | ||||||
|     repositories { |     id 'nu.studer.credentials' version('1.0.4') | ||||||
|         maven { url 'http://nexus.red-soft.biz/repository/public' } |     id 'idea' | ||||||
|         mavenLocal() |     id 'eclipse' | ||||||
|     } |     id 'application' | ||||||
|     dependencies { |     id 'java-library' | ||||||
|         classpath 'biz.redsoft.gradle.ncore:gradle-ncore:1.2.+' |     id 'war' | ||||||
|         classpath 'nu.studer:gradle-credentials-plugin:1.0.4' |     id 'gradle-ncore' version("$pluginVersion") | ||||||
|     } |  | ||||||
| } | } | ||||||
|  |  | ||||||
| group = 'biz.redsoft.sample' | //apply from: "dependencies.gradle" | ||||||
|  |  | ||||||
| apply plugin: 'nu.studer.credentials' |  | ||||||
| apply plugin: 'idea' |  | ||||||
| apply plugin: 'application' |  | ||||||
| apply plugin: 'war' |  | ||||||
| apply plugin: 'ncore' |  | ||||||
|  |  | ||||||
| targetCompatibility = 1.8 | targetCompatibility = 1.8 | ||||||
|  |  | ||||||
| @ -24,10 +17,11 @@ ncore { | |||||||
|     sourceEncoding = 'UTF-8' |     sourceEncoding = 'UTF-8' | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| repositories { | repositories { | ||||||
|     mavenLocal() |  | ||||||
|     maven { |     maven { | ||||||
|         url 'http://nexus.red-soft.biz/repository/public' |         url 'https://ncore-repo.red-soft.ru/repository/ncore' | ||||||
|         if (project.credentials.user != null && project.credentials.password != null) { |         if (project.credentials.user != null && project.credentials.password != null) { | ||||||
|             credentials { |             credentials { | ||||||
|                 username project.credentials.user |                 username project.credentials.user | ||||||
| @ -38,13 +32,15 @@ repositories { | |||||||
| } | } | ||||||
|  |  | ||||||
| dependencies { | dependencies { | ||||||
|     testImplementation 'junit:junit:4.13.1' |     implementation 'javax.servlet:javax.servlet-api:3.1.0' | ||||||
|  |     testCompileClasspath 'org.junit.jupiter:junit-jupiter:5.8.2' | ||||||
|     provided 'javax.servlet:javax.servlet-api:3.1.0' |     testImplementation 'org.apache.tomcat.embed:tomcat-embed-core:9.0.76' | ||||||
|  |     testImplementation 'org.apache.tomcat.embed:tomcat-embed-jasper:9.0.76' | ||||||
|     testCompile 'org.junit.jupiter:junit-jupiter:5.8.2' |     runtimeClasspath files(ncoreGenerateControlDataJar) | ||||||
|  |     runtimeClasspath files(genJar) | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| // writing build process to a log file | // writing build process to a log file | ||||||
| // --------------------- BUILD LOG SETTINGS ---------------------- | // --------------------- BUILD LOG SETTINGS ---------------------- | ||||||
| def tstamp = new Date().format('yyyy-MM-dd_HH-mm-ss') | def tstamp = new Date().format('yyyy-MM-dd_HH-mm-ss') | ||||||
| @ -52,7 +48,11 @@ def buildLogDir = "${rootDir}/logs" | |||||||
| mkdir("${buildLogDir}") | mkdir("${buildLogDir}") | ||||||
| def buildLog = new File("${buildLogDir}/${tstamp}_buildLog.log") | def buildLog = new File("${buildLogDir}/${tstamp}_buildLog.log") | ||||||
|  |  | ||||||
| import org.gradle.internal.logging.* |  | ||||||
|  | import org.gradle.internal.logging.LoggingOutputInternal | ||||||
|  |  | ||||||
|  | import java.util.regex.Matcher | ||||||
|  |  | ||||||
| System.setProperty('org.gradle.color.error', 'RED') | System.setProperty('org.gradle.color.error', 'RED') | ||||||
|  |  | ||||||
| gradle.services.get(LoggingOutputInternal).addStandardOutputListener(new StandardOutputListener() { | gradle.services.get(LoggingOutputInternal).addStandardOutputListener(new StandardOutputListener() { | ||||||
| @ -74,6 +74,7 @@ run.args = ['client', | |||||||
|  |  | ||||||
| task copyDist(type: Copy) { | task copyDist(type: Copy) { | ||||||
|     from distZip |     from distZip | ||||||
|  |     from distTar | ||||||
|     from war |     from war | ||||||
|     def releaseDir |     def releaseDir | ||||||
|     if (project.hasProperty('biz.redsoft.release.dir') && project.getProperty('biz.redsoft.release.dir')) |     if (project.hasProperty('biz.redsoft.release.dir') && project.getProperty('biz.redsoft.release.dir')) | ||||||
| @ -83,12 +84,55 @@ task copyDist(type: Copy) { | |||||||
|     into "$releaseDir/$project.name/$version" |     into "$releaseDir/$project.name/$version" | ||||||
| } | } | ||||||
|  |  | ||||||
|  | def versionPropertiesFilePath = sourceSets.main.resources.srcDirs[0].toString() + File.separator + "META-INF/ncore-product/${project.group}/version.properties" | ||||||
|  |  | ||||||
| release { | release { | ||||||
|     tagPrefix = 'v' |     commitNewVersion.enabled(true) | ||||||
|  |     failOnCommitNeeded = false | ||||||
|  |     failOnPublishNeeded = true | ||||||
|  |     failOnSnapshotDependencies = true | ||||||
|  |     failOnUnversionedFiles = false | ||||||
|  |     failOnUpdateNeeded = false | ||||||
|  |     revertOnFail = true | ||||||
|  |     preCommitText = '' | ||||||
|  |     preTagCommitMessage = '[Gradle Release Plugin] - pre tag commit: ' | ||||||
|  |     tagCommitMessage = '[Gradle Release Plugin] - creating tag: ' | ||||||
|  |     newVersionCommitMessage = '[Gradle Release Plugin] - new version commit: ' | ||||||
|  |     tagTemplate = "${project.name}/v${version}" | ||||||
|  |     versionPropertyFile = versionPropertiesFilePath | ||||||
|  |     versionProperties = [] | ||||||
|  |     snapshotSuffix = '-SNAPSHOT' | ||||||
|  |     buildTasks = ['buildRelease', 'commitNewVersion'] | ||||||
|  |     ignoredSnapshotDependencies = [] | ||||||
|  |     versionPatterns = [ | ||||||
|  |             /(\d+)(\.)(\d+)(\.)(\d+)([^\d]*\u0024)/: { Matcher m, Project p -> | ||||||
|  |                 project.getVersion().newVersion().toString() | ||||||
|  |             } | ||||||
|  |     ] | ||||||
|  |     pushReleaseVersionBranch = null | ||||||
| } | } | ||||||
|  |  | ||||||
| task buildRelease(type: GradleBuild) { | task buildRelease(type: GradleBuild) { | ||||||
|     tasks = ['clean', 'writeVersion', 'nbackup', 'build', 'copyDist', 'publish'] |     tasks = ['clean', 'writeVersion', 'nbackup', 'build', 'copyDist', 'publish'] | ||||||
| } | } | ||||||
|  |  | ||||||
| idea { module.scopes.PROVIDED.plus += [configurations.provided] } |  | ||||||
|  | jar{ | ||||||
|  |     manifest{ | ||||||
|  |         attributes( | ||||||
|  |                 'Main-Class': 'biz.redsoft.ncore.client.MainForm', | ||||||
|  |                 'Class-Path': configurations.runtimeClasspath.collect { it.name }.join(' ') | ||||||
|  |         ) | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | startScripts { | ||||||
|  |     project.startScripts.defaultJvmOpts = ['-Dlogback.configurationFile=./config/logback.xml'] | ||||||
|  | } | ||||||
|  |  | ||||||
|  | distTar { | ||||||
|  |     duplicatesStrategy = DuplicatesStrategy.EXCLUDE | ||||||
|  | } | ||||||
|  | distZip { | ||||||
|  |     duplicatesStrategy = DuplicatesStrategy.EXCLUDE | ||||||
|  | } | ||||||
							
								
								
									
										13
									
								
								creds.gradle
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								creds.gradle
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,13 @@ | |||||||
|  | buildscript { | ||||||
|  |     repositories { | ||||||
|  |         maven { | ||||||
|  |           url 'https://nexus.red-soft.ru/repository/ncore-public' | ||||||
|  |         } | ||||||
|  |         mavenLocal() | ||||||
|  |     } | ||||||
|  |     dependencies { | ||||||
|  |         classpath 'nu.studer:gradle-credentials-plugin:1.0.7' | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | apply plugin: 'nu.studer.credentials' | ||||||
							
								
								
									
										
											BIN
										
									
								
								db/ncore.7z
									
									
									
									
									
								
							
							
						
						
									
										
											BIN
										
									
								
								db/ncore.7z
									
									
									
									
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								db/ncore.zip
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								db/ncore.zip
									
									
									
									
									
										Executable file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										12
									
								
								dependencies.gradle
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								dependencies.gradle
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,12 @@ | |||||||
|  | repositories { | ||||||
|  |     mavenLocal() | ||||||
|  |     maven { | ||||||
|  |         url 'https://ncore-repo.red-soft.ru/repository/public' | ||||||
|  |         if (project.credentials.user != null && project.credentials.password != null) { | ||||||
|  |             credentials { | ||||||
|  |                 username project.credentials.user | ||||||
|  |                 password project.credentials.password | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -1 +1,2 @@ | |||||||
| biz.redsoft.ncore.version=1.8.44.67 | biz.redsoft.ncore.version=1.9.19.251 | ||||||
|  | pluginVersion=3.0.82 | ||||||
|  | |||||||
							
								
								
									
										
											BIN
										
									
								
								gradle/wrapper/gradle-wrapper.jar
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										
											BIN
										
									
								
								gradle/wrapper/gradle-wrapper.jar
									
									
									
									
										vendored
									
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										4
									
								
								gradle/wrapper/gradle-wrapper.properties
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								gradle/wrapper/gradle-wrapper.properties
									
									
									
									
										vendored
									
									
								
							| @ -1,6 +1,6 @@ | |||||||
| #Wed Oct 02 13:02:10 MSK 2019 |  | ||||||
| distributionBase=GRADLE_USER_HOME | distributionBase=GRADLE_USER_HOME | ||||||
| distributionPath=wrapper/dists | distributionPath=wrapper/dists | ||||||
|  | distributionUrl=https\://services.gradle.org/distributions/gradle-7.6.4-bin.zip | ||||||
|  | networkTimeout=10000 | ||||||
| zipStoreBase=GRADLE_USER_HOME | zipStoreBase=GRADLE_USER_HOME | ||||||
| zipStorePath=wrapper/dists | zipStorePath=wrapper/dists | ||||||
| distributionUrl=https\://services.gradle.org/distributions/gradle-4.10.3-bin.zip |  | ||||||
|  | |||||||
							
								
								
									
										302
									
								
								gradlew
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										302
									
								
								gradlew
									
									
									
									
										vendored
									
									
								
							| @ -1,78 +1,129 @@ | |||||||
| #!/usr/bin/env bash | #!/bin/sh | ||||||
|  |  | ||||||
|  | # | ||||||
|  | # Copyright © 2015-2021 the original authors. | ||||||
|  | # | ||||||
|  | # Licensed under the Apache License, Version 2.0 (the "License"); | ||||||
|  | # you may not use this file except in compliance with the License. | ||||||
|  | # You may obtain a copy of the License at | ||||||
|  | # | ||||||
|  | #      https://www.apache.org/licenses/LICENSE-2.0 | ||||||
|  | # | ||||||
|  | # Unless required by applicable law or agreed to in writing, software | ||||||
|  | # distributed under the License is distributed on an "AS IS" BASIS, | ||||||
|  | # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||||
|  | # See the License for the specific language governing permissions and | ||||||
|  | # limitations under the License. | ||||||
|  | # | ||||||
|  |  | ||||||
| ############################################################################## | ############################################################################## | ||||||
| ## | # | ||||||
| ##  Gradle start up script for UN*X | #   Gradle start up script for POSIX generated by Gradle. | ||||||
| ## | # | ||||||
|  | #   Important for running: | ||||||
|  | # | ||||||
|  | #   (1) You need a POSIX-compliant shell to run this script. If your /bin/sh is | ||||||
|  | #       noncompliant, but you have some other compliant shell such as ksh or | ||||||
|  | #       bash, then to run this script, type that shell name before the whole | ||||||
|  | #       command line, like: | ||||||
|  | # | ||||||
|  | #           ksh Gradle | ||||||
|  | # | ||||||
|  | #       Busybox and similar reduced shells will NOT work, because this script | ||||||
|  | #       requires all of these POSIX shell features: | ||||||
|  | #         * functions; | ||||||
|  | #         * expansions «$var», «${var}», «${var:-default}», «${var+SET}», | ||||||
|  | #           «${var#prefix}», «${var%suffix}», and «$( cmd )»; | ||||||
|  | #         * compound commands having a testable exit status, especially «case»; | ||||||
|  | #         * various built-in commands including «command», «set», and «ulimit». | ||||||
|  | # | ||||||
|  | #   Important for patching: | ||||||
|  | # | ||||||
|  | #   (2) This script targets any POSIX shell, so it avoids extensions provided | ||||||
|  | #       by Bash, Ksh, etc; in particular arrays are avoided. | ||||||
|  | # | ||||||
|  | #       The "traditional" practice of packing multiple parameters into a | ||||||
|  | #       space-separated string is a well documented source of bugs and security | ||||||
|  | #       problems, so this is (mostly) avoided, by progressively accumulating | ||||||
|  | #       options in "$@", and eventually passing that to Java. | ||||||
|  | # | ||||||
|  | #       Where the inherited environment variables (DEFAULT_JVM_OPTS, JAVA_OPTS, | ||||||
|  | #       and GRADLE_OPTS) rely on word-splitting, this is performed explicitly; | ||||||
|  | #       see the in-line comments for details. | ||||||
|  | # | ||||||
|  | #       There are tweaks for specific operating systems such as AIX, CygWin, | ||||||
|  | #       Darwin, MinGW, and NonStop. | ||||||
|  | # | ||||||
|  | #   (3) This script is generated from the Groovy template | ||||||
|  | #       https://github.com/gradle/gradle/blob/HEAD/subprojects/plugins/src/main/resources/org/gradle/api/internal/plugins/unixStartScript.txt | ||||||
|  | #       within the Gradle project. | ||||||
|  | # | ||||||
|  | #       You can find Gradle at https://github.com/gradle/gradle/. | ||||||
|  | # | ||||||
| ############################################################################## | ############################################################################## | ||||||
|  |  | ||||||
| # Attempt to set APP_HOME | # Attempt to set APP_HOME | ||||||
| # Resolve links: $0 may be a link |  | ||||||
| PRG="$0" |  | ||||||
| # Need this for relative symlinks. |  | ||||||
| while [ -h "$PRG" ] ; do |  | ||||||
|     ls=`ls -ld "$PRG"` |  | ||||||
|     link=`expr "$ls" : '.*-> \(.*\)$'` |  | ||||||
|     if expr "$link" : '/.*' > /dev/null; then |  | ||||||
|         PRG="$link" |  | ||||||
|     else |  | ||||||
|         PRG=`dirname "$PRG"`"/$link" |  | ||||||
|     fi |  | ||||||
| done |  | ||||||
| SAVED="`pwd`" |  | ||||||
| cd "`dirname \"$PRG\"`/" >/dev/null |  | ||||||
| APP_HOME="`pwd -P`" |  | ||||||
| cd "$SAVED" >/dev/null |  | ||||||
|  |  | ||||||
| APP_NAME="Gradle" | # Resolve links: $0 may be a link | ||||||
| APP_BASE_NAME=`basename "$0"` | app_path=$0 | ||||||
|  |  | ||||||
|  | # Need this for daisy-chained symlinks. | ||||||
|  | while | ||||||
|  |     APP_HOME=${app_path%"${app_path##*/}"}  # leaves a trailing /; empty if no leading path | ||||||
|  |     [ -h "$app_path" ] | ||||||
|  | do | ||||||
|  |     ls=$( ls -ld "$app_path" ) | ||||||
|  |     link=${ls#*' -> '} | ||||||
|  |     case $link in             #( | ||||||
|  |       /*)   app_path=$link ;; #( | ||||||
|  |       *)    app_path=$APP_HOME$link ;; | ||||||
|  |     esac | ||||||
|  | done | ||||||
|  |  | ||||||
|  | # This is normally unused | ||||||
|  | # shellcheck disable=SC2034 | ||||||
|  | APP_BASE_NAME=${0##*/} | ||||||
|  | APP_HOME=$( cd "${APP_HOME:-./}" && pwd -P ) || exit | ||||||
|  |  | ||||||
| # Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. | # Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. | ||||||
| DEFAULT_JVM_OPTS="" | DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"' | ||||||
|  |  | ||||||
| # Use the maximum available, or set MAX_FD != -1 to use that value. | # Use the maximum available, or set MAX_FD != -1 to use that value. | ||||||
| MAX_FD="maximum" | MAX_FD=maximum | ||||||
|  |  | ||||||
| warn () { | warn () { | ||||||
|     echo "$*" |     echo "$*" | ||||||
| } | } >&2 | ||||||
|  |  | ||||||
| die () { | die () { | ||||||
|     echo |     echo | ||||||
|     echo "$*" |     echo "$*" | ||||||
|     echo |     echo | ||||||
|     exit 1 |     exit 1 | ||||||
| } | } >&2 | ||||||
|  |  | ||||||
| # OS specific support (must be 'true' or 'false'). | # OS specific support (must be 'true' or 'false'). | ||||||
| cygwin=false | cygwin=false | ||||||
| msys=false | msys=false | ||||||
| darwin=false | darwin=false | ||||||
| nonstop=false | nonstop=false | ||||||
| case "`uname`" in | case "$( uname )" in                #( | ||||||
|   CYGWIN* ) |   CYGWIN* )         cygwin=true  ;; #( | ||||||
|     cygwin=true |   Darwin* )         darwin=true  ;; #( | ||||||
|     ;; |   MSYS* | MINGW* )  msys=true    ;; #( | ||||||
|   Darwin* ) |   NONSTOP* )        nonstop=true ;; | ||||||
|     darwin=true |  | ||||||
|     ;; |  | ||||||
|   MINGW* ) |  | ||||||
|     msys=true |  | ||||||
|     ;; |  | ||||||
|   NONSTOP* ) |  | ||||||
|     nonstop=true |  | ||||||
|     ;; |  | ||||||
| esac | esac | ||||||
|  |  | ||||||
| CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar | CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar | ||||||
|  |  | ||||||
|  |  | ||||||
| # Determine the Java command to use to start the JVM. | # Determine the Java command to use to start the JVM. | ||||||
| if [ -n "$JAVA_HOME" ] ; then | if [ -n "$JAVA_HOME" ] ; then | ||||||
|     if [ -x "$JAVA_HOME/jre/sh/java" ] ; then |     if [ -x "$JAVA_HOME/jre/sh/java" ] ; then | ||||||
|         # IBM's JDK on AIX uses strange locations for the executables |         # IBM's JDK on AIX uses strange locations for the executables | ||||||
|         JAVACMD="$JAVA_HOME/jre/sh/java" |         JAVACMD=$JAVA_HOME/jre/sh/java | ||||||
|     else |     else | ||||||
|         JAVACMD="$JAVA_HOME/bin/java" |         JAVACMD=$JAVA_HOME/bin/java | ||||||
|     fi |     fi | ||||||
|     if [ ! -x "$JAVACMD" ] ; then |     if [ ! -x "$JAVACMD" ] ; then | ||||||
|         die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME |         die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME | ||||||
| @ -81,7 +132,7 @@ Please set the JAVA_HOME variable in your environment to match the | |||||||
| location of your Java installation." | location of your Java installation." | ||||||
|     fi |     fi | ||||||
| else | else | ||||||
|     JAVACMD="java" |     JAVACMD=java | ||||||
|     which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. |     which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. | ||||||
|  |  | ||||||
| Please set the JAVA_HOME variable in your environment to match the | Please set the JAVA_HOME variable in your environment to match the | ||||||
| @ -89,76 +140,105 @@ location of your Java installation." | |||||||
| fi | fi | ||||||
|  |  | ||||||
| # Increase the maximum file descriptors if we can. | # Increase the maximum file descriptors if we can. | ||||||
| if [ "$cygwin" = "false" -a "$darwin" = "false" -a "$nonstop" = "false" ] ; then | if ! "$cygwin" && ! "$darwin" && ! "$nonstop" ; then | ||||||
|     MAX_FD_LIMIT=`ulimit -H -n` |     case $MAX_FD in #( | ||||||
|     if [ $? -eq 0 ] ; then |       max*) | ||||||
|         if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then |         # In POSIX sh, ulimit -H is undefined. That's why the result is checked to see if it worked. | ||||||
|             MAX_FD="$MAX_FD_LIMIT" |         # shellcheck disable=SC3045  | ||||||
|         fi |         MAX_FD=$( ulimit -H -n ) || | ||||||
|         ulimit -n $MAX_FD |             warn "Could not query maximum file descriptor limit" | ||||||
|         if [ $? -ne 0 ] ; then |     esac | ||||||
|             warn "Could not set maximum file descriptor limit: $MAX_FD" |     case $MAX_FD in  #( | ||||||
|         fi |       '' | soft) :;; #( | ||||||
|     else |       *) | ||||||
|         warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT" |         # In POSIX sh, ulimit -n is undefined. That's why the result is checked to see if it worked. | ||||||
|     fi |         # shellcheck disable=SC3045  | ||||||
| fi |         ulimit -n "$MAX_FD" || | ||||||
|  |             warn "Could not set maximum file descriptor limit to $MAX_FD" | ||||||
| # For Darwin, add options to specify how the application appears in the dock |  | ||||||
| if $darwin; then |  | ||||||
|     GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\"" |  | ||||||
| fi |  | ||||||
|  |  | ||||||
| # For Cygwin, switch paths to Windows format before running java |  | ||||||
| if $cygwin ; then |  | ||||||
|     APP_HOME=`cygpath --path --mixed "$APP_HOME"` |  | ||||||
|     CLASSPATH=`cygpath --path --mixed "$CLASSPATH"` |  | ||||||
|     JAVACMD=`cygpath --unix "$JAVACMD"` |  | ||||||
|  |  | ||||||
|     # We build the pattern for arguments to be converted via cygpath |  | ||||||
|     ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null` |  | ||||||
|     SEP="" |  | ||||||
|     for dir in $ROOTDIRSRAW ; do |  | ||||||
|         ROOTDIRS="$ROOTDIRS$SEP$dir" |  | ||||||
|         SEP="|" |  | ||||||
|     done |  | ||||||
|     OURCYGPATTERN="(^($ROOTDIRS))" |  | ||||||
|     # Add a user-defined pattern to the cygpath arguments |  | ||||||
|     if [ "$GRADLE_CYGPATTERN" != "" ] ; then |  | ||||||
|         OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)" |  | ||||||
|     fi |  | ||||||
|     # Now convert the arguments - kludge to limit ourselves to /bin/sh |  | ||||||
|     i=0 |  | ||||||
|     for arg in "$@" ; do |  | ||||||
|         CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -` |  | ||||||
|         CHECK2=`echo "$arg"|egrep -c "^-"`                                 ### Determine if an option |  | ||||||
|  |  | ||||||
|         if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then                    ### Added a condition |  | ||||||
|             eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"` |  | ||||||
|         else |  | ||||||
|             eval `echo args$i`="\"$arg\"" |  | ||||||
|         fi |  | ||||||
|         i=$((i+1)) |  | ||||||
|     done |  | ||||||
|     case $i in |  | ||||||
|         (0) set -- ;; |  | ||||||
|         (1) set -- "$args0" ;; |  | ||||||
|         (2) set -- "$args0" "$args1" ;; |  | ||||||
|         (3) set -- "$args0" "$args1" "$args2" ;; |  | ||||||
|         (4) set -- "$args0" "$args1" "$args2" "$args3" ;; |  | ||||||
|         (5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;; |  | ||||||
|         (6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;; |  | ||||||
|         (7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;; |  | ||||||
|         (8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;; |  | ||||||
|         (9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;; |  | ||||||
|     esac |     esac | ||||||
| fi | fi | ||||||
|  |  | ||||||
| # Split up the JVM_OPTS And GRADLE_OPTS values into an array, following the shell quoting and substitution rules | # Collect all arguments for the java command, stacking in reverse order: | ||||||
| function splitJvmOpts() { | #   * args from the command line | ||||||
|     JVM_OPTS=("$@") | #   * the main class name | ||||||
| } | #   * -classpath | ||||||
| eval splitJvmOpts $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS | #   * -D...appname settings | ||||||
| JVM_OPTS[${#JVM_OPTS[*]}]="-Dorg.gradle.appname=$APP_BASE_NAME" | #   * --module-path (only if needed) | ||||||
|  | #   * DEFAULT_JVM_OPTS, JAVA_OPTS, and GRADLE_OPTS environment variables. | ||||||
|  |  | ||||||
| exec "$JAVACMD" "${JVM_OPTS[@]}" -classpath "$CLASSPATH" org.gradle.wrapper.GradleWrapperMain "$@" | # For Cygwin or MSYS, switch paths to Windows format before running java | ||||||
|  | if "$cygwin" || "$msys" ; then | ||||||
|  |     APP_HOME=$( cygpath --path --mixed "$APP_HOME" ) | ||||||
|  |     CLASSPATH=$( cygpath --path --mixed "$CLASSPATH" ) | ||||||
|  |  | ||||||
|  |     JAVACMD=$( cygpath --unix "$JAVACMD" ) | ||||||
|  |  | ||||||
|  |     # Now convert the arguments - kludge to limit ourselves to /bin/sh | ||||||
|  |     for arg do | ||||||
|  |         if | ||||||
|  |             case $arg in                                #( | ||||||
|  |               -*)   false ;;                            # don't mess with options #( | ||||||
|  |               /?*)  t=${arg#/} t=/${t%%/*}              # looks like a POSIX filepath | ||||||
|  |                     [ -e "$t" ] ;;                      #( | ||||||
|  |               *)    false ;; | ||||||
|  |             esac | ||||||
|  |         then | ||||||
|  |             arg=$( cygpath --path --ignore --mixed "$arg" ) | ||||||
|  |         fi | ||||||
|  |         # Roll the args list around exactly as many times as the number of | ||||||
|  |         # args, so each arg winds up back in the position where it started, but | ||||||
|  |         # possibly modified. | ||||||
|  |         # | ||||||
|  |         # NB: a `for` loop captures its iteration list before it begins, so | ||||||
|  |         # changing the positional parameters here affects neither the number of | ||||||
|  |         # iterations, nor the values presented in `arg`. | ||||||
|  |         shift                   # remove old arg | ||||||
|  |         set -- "$@" "$arg"      # push replacement arg | ||||||
|  |     done | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | # Collect all arguments for the java command; | ||||||
|  | #   * $DEFAULT_JVM_OPTS, $JAVA_OPTS, and $GRADLE_OPTS can contain fragments of | ||||||
|  | #     shell script including quotes and variable substitutions, so put them in | ||||||
|  | #     double quotes to make sure that they get re-expanded; and | ||||||
|  | #   * put everything else in single quotes, so that it's not re-expanded. | ||||||
|  |  | ||||||
|  | set -- \ | ||||||
|  |         "-Dorg.gradle.appname=$APP_BASE_NAME" \ | ||||||
|  |         -classpath "$CLASSPATH" \ | ||||||
|  |         org.gradle.wrapper.GradleWrapperMain \ | ||||||
|  |         "$@" | ||||||
|  |  | ||||||
|  | # Stop when "xargs" is not available. | ||||||
|  | if ! command -v xargs >/dev/null 2>&1 | ||||||
|  | then | ||||||
|  |     die "xargs is not available" | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | # Use "xargs" to parse quoted args. | ||||||
|  | # | ||||||
|  | # With -n1 it outputs one arg per line, with the quotes and backslashes removed. | ||||||
|  | # | ||||||
|  | # In Bash we could simply go: | ||||||
|  | # | ||||||
|  | #   readarray ARGS < <( xargs -n1 <<<"$var" ) && | ||||||
|  | #   set -- "${ARGS[@]}" "$@" | ||||||
|  | # | ||||||
|  | # but POSIX shell has neither arrays nor command substitution, so instead we | ||||||
|  | # post-process each arg (as a line of input to sed) to backslash-escape any | ||||||
|  | # character that might be a shell metacharacter, then use eval to reverse | ||||||
|  | # that process (while maintaining the separation between arguments), and wrap | ||||||
|  | # the whole thing up as a single "set" statement. | ||||||
|  | # | ||||||
|  | # This will of course break if any of these variables contains a newline or | ||||||
|  | # an unmatched quote. | ||||||
|  | # | ||||||
|  |  | ||||||
|  | eval "set -- $( | ||||||
|  |         printf '%s\n' "$DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS" | | ||||||
|  |         xargs -n1 | | ||||||
|  |         sed ' s~[^-[:alnum:]+,./:=@_]~\\&~g; ' | | ||||||
|  |         tr '\n' ' ' | ||||||
|  |     )" '"$@"' | ||||||
|  |  | ||||||
|  | exec "$JAVACMD" "$@" | ||||||
|  | |||||||
							
								
								
									
										58
									
								
								gradlew.bat
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										58
									
								
								gradlew.bat
									
									
									
									
										vendored
									
									
								
							| @ -1,3 +1,19 @@ | |||||||
|  | @rem | ||||||
|  | @rem Copyright 2015 the original author or authors. | ||||||
|  | @rem | ||||||
|  | @rem Licensed under the Apache License, Version 2.0 (the "License"); | ||||||
|  | @rem you may not use this file except in compliance with the License. | ||||||
|  | @rem You may obtain a copy of the License at | ||||||
|  | @rem | ||||||
|  | @rem      https://www.apache.org/licenses/LICENSE-2.0 | ||||||
|  | @rem | ||||||
|  | @rem Unless required by applicable law or agreed to in writing, software | ||||||
|  | @rem distributed under the License is distributed on an "AS IS" BASIS, | ||||||
|  | @rem WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||||
|  | @rem See the License for the specific language governing permissions and | ||||||
|  | @rem limitations under the License. | ||||||
|  | @rem | ||||||
|  |  | ||||||
| @if "%DEBUG%"=="" @echo off | @if "%DEBUG%"=="" @echo off | ||||||
| @rem ########################################################################## | @rem ########################################################################## | ||||||
| @rem | @rem | ||||||
| @ -10,18 +26,22 @@ if "%OS%"=="Windows_NT" setlocal | |||||||
|  |  | ||||||
| set DIRNAME=%~dp0 | set DIRNAME=%~dp0 | ||||||
| if "%DIRNAME%"=="" set DIRNAME=. | if "%DIRNAME%"=="" set DIRNAME=. | ||||||
|  | @rem This is normally unused | ||||||
| set APP_BASE_NAME=%~n0 | set APP_BASE_NAME=%~n0 | ||||||
| set APP_HOME=%DIRNAME% | set APP_HOME=%DIRNAME% | ||||||
|  |  | ||||||
|  | @rem Resolve any "." and ".." in APP_HOME to make it shorter. | ||||||
|  | for %%i in ("%APP_HOME%") do set APP_HOME=%%~fi | ||||||
|  |  | ||||||
| @rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. | @rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. | ||||||
| set DEFAULT_JVM_OPTS= | set DEFAULT_JVM_OPTS="-Xmx64m" "-Xms64m" | ||||||
|  |  | ||||||
| @rem Find java.exe | @rem Find java.exe | ||||||
| if defined JAVA_HOME goto findJavaFromJavaHome | if defined JAVA_HOME goto findJavaFromJavaHome | ||||||
|  |  | ||||||
| set JAVA_EXE=java.exe | set JAVA_EXE=java.exe | ||||||
| %JAVA_EXE% -version >NUL 2>&1 | %JAVA_EXE% -version >NUL 2>&1 | ||||||
| if "%ERRORLEVEL%" == "0" goto init | if %ERRORLEVEL% equ 0 goto execute | ||||||
|  |  | ||||||
| echo. | echo. | ||||||
| echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. | echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. | ||||||
| @ -35,7 +55,7 @@ goto fail | |||||||
| set JAVA_HOME=%JAVA_HOME:"=% | set JAVA_HOME=%JAVA_HOME:"=% | ||||||
| set JAVA_EXE=%JAVA_HOME%/bin/java.exe | set JAVA_EXE=%JAVA_HOME%/bin/java.exe | ||||||
|  |  | ||||||
| if exist "%JAVA_EXE%" goto init | if exist "%JAVA_EXE%" goto execute | ||||||
|  |  | ||||||
| echo. | echo. | ||||||
| echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% | echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% | ||||||
| @ -45,44 +65,26 @@ echo location of your Java installation. | |||||||
|  |  | ||||||
| goto fail | goto fail | ||||||
|  |  | ||||||
| :init |  | ||||||
| @rem Get command-line arguments, handling Windows variants |  | ||||||
|  |  | ||||||
| if not "%OS%" == "Windows_NT" goto win9xME_args |  | ||||||
| if "%@eval[2+2]" == "4" goto 4NT_args |  | ||||||
|  |  | ||||||
| :win9xME_args |  | ||||||
| @rem Slurp the command line arguments. |  | ||||||
| set CMD_LINE_ARGS= |  | ||||||
| set _SKIP=2 |  | ||||||
|  |  | ||||||
| :win9xME_args_slurp |  | ||||||
| if "x%~1" == "x" goto execute |  | ||||||
|  |  | ||||||
| set CMD_LINE_ARGS=%* |  | ||||||
| goto execute |  | ||||||
|  |  | ||||||
| :4NT_args |  | ||||||
| @rem Get arguments from the 4NT Shell from JP Software |  | ||||||
| set CMD_LINE_ARGS=%$ |  | ||||||
|  |  | ||||||
| :execute | :execute | ||||||
| @rem Setup the command line | @rem Setup the command line | ||||||
|  |  | ||||||
| set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar | set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar | ||||||
|  |  | ||||||
|  |  | ||||||
| @rem Execute Gradle | @rem Execute Gradle | ||||||
| "%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS% | "%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %* | ||||||
|  |  | ||||||
| :end | :end | ||||||
| @rem End local scope for the variables with windows NT shell | @rem End local scope for the variables with windows NT shell | ||||||
| if "%ERRORLEVEL%"=="0" goto mainEnd | if %ERRORLEVEL% equ 0 goto mainEnd | ||||||
|  |  | ||||||
| :fail | :fail | ||||||
| rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of | rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of | ||||||
| rem the _cmd.exe /c_ return code! | rem the _cmd.exe /c_ return code! | ||||||
| if  not "" == "%GRADLE_EXIT_CONSOLE%" exit 1 | set EXIT_CODE=%ERRORLEVEL% | ||||||
| exit /b 1 | if %EXIT_CODE% equ 0 set EXIT_CODE=1 | ||||||
|  | if not ""=="%GRADLE_EXIT_CONSOLE%" exit %EXIT_CODE% | ||||||
|  | exit /b %EXIT_CODE% | ||||||
|  |  | ||||||
| :mainEnd | :mainEnd | ||||||
| if "%OS%"=="Windows_NT" endlocal | if "%OS%"=="Windows_NT" endlocal | ||||||
|  | |||||||
| @ -3,4 +3,7 @@ | |||||||
| <properties> | <properties> | ||||||
|   <entry key="ncore.developer.mode">true</entry> |   <entry key="ncore.developer.mode">true</entry> | ||||||
| <!--  <entry key="ncore.db.url">jdbc:firebirdsql:localhost:ncore-sample-dev?lc_ctype=WIN1251</entry> --> | <!--  <entry key="ncore.db.url">jdbc:firebirdsql:localhost:ncore-sample-dev?lc_ctype=WIN1251</entry> --> | ||||||
|  |   <!-- Для автоматизированного рестора базы данных запустить gradlew nRDB--> | ||||||
|  |   <entry key="ncore.db.backup.path">db/ncore.zip</entry> | ||||||
|  |   <entry key="ncore.db.restore.path">/db/ncore-sample.fdb</entry> | ||||||
| </properties> | </properties> | ||||||
|  | |||||||
| @ -1 +1,7 @@ | |||||||
|  | pluginManagement{ | ||||||
|  |     repositories { | ||||||
|  |         maven { url 'https://ncore-repo.red-soft.ru/repository/public' } | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
| rootProject.name = 'sample' | rootProject.name = 'sample' | ||||||
							
								
								
									
										2
									
								
								src/dist/bin/starter
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								src/dist/bin/starter
									
									
									
									
										vendored
									
									
								
							| @ -1,5 +1,5 @@ | |||||||
| #!/bin/bash | #!/bin/bash | ||||||
|  |  | ||||||
| cd $(dirname $0)/.. | cd $(dirname $0)/.. | ||||||
| bin/ncore $1 -config config/ncore-properties.xml $2 $3 $4 $5 | bin/sample $1 -config config/ncore-properties.xml $2 $3 $4 $5 | ||||||
| cd $OLDPWD | cd $OLDPWD | ||||||
							
								
								
									
										2
									
								
								src/dist/bin/starter.bat
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								src/dist/bin/starter.bat
									
									
									
									
										vendored
									
									
								
							| @ -1,5 +1,5 @@ | |||||||
| @echo off | @echo off | ||||||
|  |  | ||||||
| pushd  "%~dp0\.." | pushd  "%~dp0\.." | ||||||
| call bin\ncore.bat %1 -config config\ncore-properties.xml %2 %3 %4 %5 | call bin\sample.bat %1 -config config\ncore-properties.xml %2 %3 %4 %5 | ||||||
| popd | popd | ||||||
							
								
								
									
										8
									
								
								src/dist/bin/sync-full
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								src/dist/bin/sync-full
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,8 @@ | |||||||
|  | #!/bin/bash | ||||||
|  |  | ||||||
|  | $(dirname $0)/starter update -fullSync -skipUpdate | ||||||
|  |  | ||||||
|  | if [ $? -ne 0 ] ; then  | ||||||
|  |     echo Error updating database | ||||||
|  |     exit 11 | ||||||
|  | fi | ||||||
							
								
								
									
										4
									
								
								src/dist/bin/sync-full.bat
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								src/dist/bin/sync-full.bat
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,4 @@ | |||||||
|  | @echo off | ||||||
|  |  | ||||||
|  | call "%~dp0\starter.bat" update -fullSync -skipUpdate | ||||||
|  | @pause | ||||||
| @ -4,9 +4,6 @@ import biz.redsoft.ncore.system.application.Application; | |||||||
|  |  | ||||||
| import java.util.Map; | import java.util.Map; | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * @author Victor Bellavin |  | ||||||
|  */ |  | ||||||
| public class Product implements biz.redsoft.ncore.product.Product { | public class Product implements biz.redsoft.ncore.product.Product { | ||||||
|   private static String PRODUCT_NAME = Product.class.getPackage().getName(); |   private static String PRODUCT_NAME = Product.class.getPackage().getName(); | ||||||
|  |  | ||||||
|  | |||||||
| @ -10,9 +10,6 @@ import java.util.Properties; | |||||||
| import org.slf4j.Logger; | import org.slf4j.Logger; | ||||||
| import org.slf4j.LoggerFactory; | import org.slf4j.LoggerFactory; | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * @author Victor Bellavin |  | ||||||
|  */ |  | ||||||
| public class Version { | public class Version { | ||||||
|     public static final Logger LOGGER = LoggerFactory.getLogger(Version.class); |     public static final Logger LOGGER = LoggerFactory.getLogger(Version.class); | ||||||
|  |  | ||||||
|  | |||||||
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 953 B | 
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 1016 B | 
| @ -37,18 +37,18 @@ | |||||||
|  </servlet> |  </servlet> | ||||||
|   <servlet-mapping> |   <servlet-mapping> | ||||||
|     <servlet-name>ncore</servlet-name> |     <servlet-name>ncore</servlet-name> | ||||||
|     <url-pattern>/client/*</url-pattern> |     <url-pattern>/*</url-pattern> | ||||||
|   </servlet-mapping> |  | ||||||
|   <servlet-mapping> |  | ||||||
|     <servlet-name>ncore</servlet-name> |  | ||||||
|     <url-pattern>/VAADIN/*</url-pattern> |  | ||||||
|   </servlet-mapping> |   </servlet-mapping> | ||||||
|  | <!-- TLS/SSL logback JNDI selector section --> | ||||||
|  | <!--  <env-entry> | ||||||
|  |     <env-entry-name>logback/context-name</env-entry-name> | ||||||
|  |     <env-entry-type>java.lang.String</env-entry-type> | ||||||
|  |     <env-entry-value>ncore</env-entry-value> | ||||||
|  |   </env-entry>--> | ||||||
|  | <!-- end of TLS/SSL logback JNDI selector section --> | ||||||
|   <listener> |   <listener> | ||||||
|     <listener-class>biz.redsoft.ncore.dx.init.DxInitializationListener</listener-class> |     <listener-class>biz.redsoft.ncore.dx.init.DxInitializationListener</listener-class> | ||||||
|   </listener> |   </listener> | ||||||
|   <welcome-file-list> |  | ||||||
|     <welcome-file>client</welcome-file> |  | ||||||
|   </welcome-file-list> |  | ||||||
|   <listener> |   <listener> | ||||||
|     <listener-class>biz.redsoft.ncore.client.vaadin.VaadinSessionListener</listener-class> |     <listener-class>biz.redsoft.ncore.client.vaadin.VaadinSessionListener</listener-class> | ||||||
|   </listener> |   </listener> | ||||||
|  | |||||||
| @ -6,8 +6,8 @@ import java.io.IOException; | |||||||
| import java.util.Arrays; | import java.util.Arrays; | ||||||
| import java.util.Properties; | import java.util.Properties; | ||||||
|  |  | ||||||
| import org.junit.Assert; | import org.junit.jupiter.api.Assertions; | ||||||
| import org.junit.Test; | import org.junit.jupiter.api.Test; | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * @author Victor Bellavin |  * @author Victor Bellavin | ||||||
| @ -17,6 +17,6 @@ public class SampleTests { | |||||||
|   public void testProductName() throws IOException { |   public void testProductName() throws IOException { | ||||||
|     final Properties props = new Properties(System.getProperties()); |     final Properties props = new Properties(System.getProperties()); | ||||||
|     Misc.loadProperties(props, Arrays.asList("ncore-properties.xml", "ncore-properties-local.xml")); |     Misc.loadProperties(props, Arrays.asList("ncore-properties.xml", "ncore-properties-local.xml")); | ||||||
|     Assert.assertEquals(props.getProperty("product.name"), "sample"); |     Assertions.assertEquals(props.getProperty("product.name"), "sample"); | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  | |||||||
							
								
								
									
										120
									
								
								src/test/java/biz/redsoft/sample/TomcatStarter.java
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										120
									
								
								src/test/java/biz/redsoft/sample/TomcatStarter.java
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,120 @@ | |||||||
|  | /* | ||||||
|  |  * Copyright (C) 2017 Red Soft Corporation. | ||||||
|  |  * | ||||||
|  |  * This file is part of Red nCore. | ||||||
|  |  * | ||||||
|  |  * Red nCore is free software; you can redistribute it and/or modify | ||||||
|  |  * it under the terms of the GNU General Public License as published by | ||||||
|  |  * the Free Software Foundation; either version 2, or (at your option) | ||||||
|  |  * any later version. | ||||||
|  |  * | ||||||
|  |  * Red nCore is distributed in the hope that it will be useful, but | ||||||
|  |  * WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | ||||||
|  |  * General Public License for more details. | ||||||
|  |  * | ||||||
|  |  * You should have received a copy of the GNU General Public License | ||||||
|  |  * along with Red nCore; see the file COPYING. If not, write to the | ||||||
|  |  * Red Soft Corporation, 117105, Russia, Moscow, Nagornyy proyezd, 5. | ||||||
|  |  * | ||||||
|  |  * Linking this library statically or dynamically with other modules is | ||||||
|  |  * making a combined work based on this library. Thus, the terms and | ||||||
|  |  * conditions of the GNU General Public License cover the whole | ||||||
|  |  * combination. | ||||||
|  |  * | ||||||
|  |  * As a special exception, the copyright holders of this library give you | ||||||
|  |  * permission to link this library with independent modules to produce an | ||||||
|  |  * executable, regardless of the license terms of these independent | ||||||
|  |  * modules, and to copy and distribute the resulting executable under | ||||||
|  |  * terms of your choice, provided that you also meet, for each linked | ||||||
|  |  * independent module, the terms and conditions of the license of that | ||||||
|  |  * module. An independent module is a module which is not derived from | ||||||
|  |  * or based on this library. If you modify this library, you may extend | ||||||
|  |  * this exception to your version of the library, but you are not | ||||||
|  |  * obligated to do so. If you do not wish to do so, delete this | ||||||
|  |  * exception statement from your version. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | package biz.redsoft.sample; | ||||||
|  |  | ||||||
|  | import java.io.File; | ||||||
|  | import java.io.IOException; | ||||||
|  | import java.io.OutputStream; | ||||||
|  | import java.net.InetAddress; | ||||||
|  | import java.net.Socket; | ||||||
|  |  | ||||||
|  | import javax.servlet.ServletException; | ||||||
|  |  | ||||||
|  | import org.apache.catalina.LifecycleException; | ||||||
|  | import org.apache.catalina.Server; | ||||||
|  | import org.apache.catalina.WebResourceRoot; | ||||||
|  | import org.apache.catalina.core.StandardContext; | ||||||
|  | import org.apache.catalina.startup.Tomcat; | ||||||
|  | import org.apache.catalina.webresources.DirResourceSet; | ||||||
|  | import org.apache.catalina.webresources.FileResourceSet; | ||||||
|  | import org.apache.catalina.webresources.StandardRoot; | ||||||
|  | import org.apache.tomcat.util.scan.StandardJarScanner; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | public class TomcatStarter { | ||||||
|  |   private String contextPath = "/ncore"; | ||||||
|  |   private int port = 8080; | ||||||
|  |  | ||||||
|  |   private int shutdownPort = 8020; | ||||||
|  |   private String shutdownCommand = "SHUTDOWN"; | ||||||
|  |  | ||||||
|  |   public void start() throws ServletException, LifecycleException { | ||||||
|  |     System.setProperty("catalina.home", new File(".").getAbsolutePath()); | ||||||
|  |     final Tomcat tomcat = new Tomcat(); | ||||||
|  |     tomcat.setPort(port); | ||||||
|  |     tomcat.setBaseDir("."); | ||||||
|  |     tomcat.getHost().setAppBase("."); | ||||||
|  |     tomcat.getConnector(); // initialize standard HTTP 1.1 connector | ||||||
|  |     tomcat.enableNaming(); | ||||||
|  |     final Server server = tomcat.getServer(); | ||||||
|  |     server.setPort(shutdownPort); | ||||||
|  |     server.setShutdown(shutdownCommand); | ||||||
|  |     final StandardContext webContext = (StandardContext) tomcat.addWebapp(contextPath, "src/main/webapp"); | ||||||
|  |     webContext.setUseNaming(true); | ||||||
|  |     final WebResourceRoot resources = new StandardRoot(webContext); | ||||||
|  |     //aliases to resources | ||||||
|  |     final String base = ap(""); | ||||||
|  |     resources.addPreResources(new DirResourceSet(resources, "/META-INF/resources", ap("src/main/resources"), "/META-INF/resources")); | ||||||
|  |     //resources.addPreResources(new DirResourceSet(resources, "/WEB-INF/classes/export_templates", base, "/export_templates")); | ||||||
|  |     if (new File(base, "ncore-properties-local.xml").exists()) | ||||||
|  |       resources.addPreResources(new FileResourceSet(resources, "/WEB-INF/ncore-properties-local.xml", base, "/ncore-properties-local.xml")); | ||||||
|  |     //resources.addPreResources(new FileResourceSet(resources, "/WEB-INF/ncore-properties-local-openid.xml", base, "/ncore-properties-local-openid.xml")); | ||||||
|  |     resources.addPreResources(new FileResourceSet(resources, "/WEB-INF/logback.xml", base, "/logback.xml")); | ||||||
|  |     webContext.setResources(resources); | ||||||
|  |     // IDEA не всегда корректно формирует пути. Отключим проверку ресурсов. | ||||||
|  |     ((StandardJarScanner)webContext.getJarScanner()).setScanClassPath(false); | ||||||
|  |     webContext.setWorkDir("build/tomcat/work"); | ||||||
|  |     tomcat.start(); | ||||||
|  |     server.await(); | ||||||
|  |     tomcat.stop(); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   private String ap(String s) { | ||||||
|  |     return new File(s).getAbsolutePath(); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   public void stop() throws IOException { | ||||||
|  |     final InetAddress serverAddress = InetAddress.getByName("localhost"); | ||||||
|  |     final Socket socket = new Socket(serverAddress, shutdownPort); | ||||||
|  |     try (OutputStream os = socket.getOutputStream()) { | ||||||
|  |       final byte[] buffer = shutdownCommand.getBytes(); | ||||||
|  |       os.write(buffer, 0, buffer.length); | ||||||
|  |       os.flush(); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   public static void main(String[] args) throws ServletException, LifecycleException, IOException { | ||||||
|  |     if (args.length > 0) { | ||||||
|  |       String command = args[0]; | ||||||
|  |       if ("start".equals(command)) | ||||||
|  |         new TomcatStarter().start(); | ||||||
|  |       else if ("stop".equals(command)) | ||||||
|  |         new TomcatStarter().stop(); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
							
								
								
									
										0
									
								
								updates/.gitkeep
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								updates/.gitkeep
									
									
									
									
									
										Normal file
									
								
							
							
								
								
									
										41
									
								
								updates/SAMPLE-0000001.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										41
									
								
								updates/SAMPLE-0000001.xml
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,41 @@ | |||||||
|  | <?xml version="1.0" encoding="UTF-8"?> | ||||||
|  | <Objects xsi:schemaLocation="http://www.red-soft.biz/2009/ncore xsd/ncore.xsd" xmlns="http://www.red-soft.biz/2009/ncore" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> | ||||||
|  |     <SysPatch CreateDate="2025-05-27T19:56:20.177" Description="Создана подсистема "SAMPLE"" Documentclassid="8001" DocDate="2025-05-27" DocNumber="SAMPLE-0000001" Metaobjectname="SYS_PATCH" | ||||||
|  |         SpNumber="1" SpRevision="1" SpStatus="2" SpSubsystem="SAMPLE" SpTimestamp="2025-05-27T19:56:20.177" SpUser="SYSDBA"> | ||||||
|  |         <DetSysLogSysPatch> | ||||||
|  |         <SysLog SlogAction="I" SlogAddress="127.0.0.1/54126" SlogSubsystem="NCORE" SlogTimestamp="2025-05-27T19:56:07.197" SlogTransaction="2808158" SlogUser="SYSDBA" | ||||||
|  |             SobjName="SYS_SUBSYSTEM"> | ||||||
|  |             <DetSysLogFieldsSysLog> | ||||||
|  |             <SysLogFields SlfFieldName="CAPTION" SlfFieldString="SAMPLE" SlfIsNew="true"/> | ||||||
|  |             <SysLogFields SlfFieldName="CODE" SlfFieldString="SAMPLE" SlfIsNew="true"/> | ||||||
|  |             <SysLogFields SlfFieldName="UPDATE_ORDER" SlfFieldString="10" SlfIsNew="true"/> | ||||||
|  |         </DetSysLogFieldsSysLog> | ||||||
|  |     </SysLog> | ||||||
|  |     <SysLog SlogAction="I" SlogAddress="127.0.0.1/54126" SlogSubsystem="SAMPLE" SlogTimestamp="2025-05-27T19:56:07.197" SlogTransaction="2808158" SlogUser="SYSDBA" | ||||||
|  |         SobjName="SYS_LOOKUP"> | ||||||
|  |         <DetSysLogFieldsSysLog> | ||||||
|  |         <SysLogFields SlfFieldName="SDOM_NAME" SlfFieldString="D_SUBSYSTEM" SlfIsNew="true"/> | ||||||
|  |         <SysLogFields SlfFieldName="SLU_CAPTION" SlfFieldString="SAMPLE" SlfIsNew="true"/> | ||||||
|  |         <SysLogFields SlfFieldName="SLU_GROUP" SlfIsNew="true"/> | ||||||
|  |         <SysLogFields SlfFieldName="SLU_KEY" SlfFieldString="SAMPLE" SlfIsNew="true"/> | ||||||
|  |         <SysLogFields SlfFieldName="SLU_MEMO" SlfIsNew="true"/> | ||||||
|  |         <SysLogFields SlfFieldName="SLU_ORDER" SlfFieldString="10" SlfIsNew="true"/> | ||||||
|  |         <SysLogFields SlfFieldName="SLU_SUBSYSTEM" SlfFieldString="SAMPLE" SlfIsNew="true"/> | ||||||
|  |     </DetSysLogFieldsSysLog> | ||||||
|  | </SysLog> | ||||||
|  | <SysLog SlogAction="U" SlogAddress="127.0.0.1/54126" SlogSubsystem="NCORE" SlogTimestamp="2025-05-27T19:56:07.197" SlogTransaction="2808158" SlogUser="SYSDBA" | ||||||
|  |     SobjName="SYS_LOOKUP"> | ||||||
|  |     <DetSysLogFieldsSysLog> | ||||||
|  |     <SysLogFields SlfFieldName="SDOM_NAME" SlfFieldString="D_SUBSYSTEM" SlfIsNew="false"/> | ||||||
|  |     <SysLogFields SlfFieldName="SLU_CAPTION" SlfFieldString="Ред Платформа" SlfIsNew="false"/> | ||||||
|  |     <SysLogFields SlfFieldName="SLU_GROUP" SlfIsNew="false"/> | ||||||
|  |     <SysLogFields SlfFieldName="SLU_KEY" SlfFieldString="NCORE" SlfIsNew="false"/> | ||||||
|  |     <SysLogFields SlfFieldName="SLU_MEMO" SlfIsNew="false"/> | ||||||
|  |     <SysLogFields SlfFieldName="SLU_ORDER" SlfFieldString="10" SlfIsNew="false"/> | ||||||
|  |     <SysLogFields SlfFieldName="SLU_ORDER" SlfFieldString="20" SlfIsNew="true"/> | ||||||
|  |     <SysLogFields SlfFieldName="SLU_SUBSYSTEM" SlfFieldString="NCORE" SlfIsNew="false"/> | ||||||
|  | </DetSysLogFieldsSysLog> | ||||||
|  | </SysLog> | ||||||
|  | </DetSysLogSysPatch> | ||||||
|  | </SysPatch> | ||||||
|  | </Objects> | ||||||
		Reference in New Issue
	
	Block a user
	