Compare commits
	
		
			68 Commits
		
	
	
		
			ncore-samp
			...
			ncore-samp
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 4c87ee8325 | |||
| 079c5a8074 | |||
| c6c7da53fa | |||
| f6ebda575a | |||
| 5124bac61b | |||
| 197efd0354 | |||
| 53c26d3b8d | |||
| 86834a4de4 | |||
| b67e2c8a75 | |||
| 2cacafb9c1 | |||
| 4b192e8e6f | |||
| 470b4c05d1 | |||
| a1cb2a6240 | |||
| 8214db2388 | |||
| 85dccc65fd | |||
| b0061ba410 | |||
| 2222a7c231 | |||
| be0b4c4dd0 | |||
| 6d9489b894 | |||
| 9f2d4c9db5 | |||
| 48fe400d01 | |||
| 195c5e701b | |||
| af1d01e503 | |||
| 6fff193d2f | |||
| 2c8d756763 | |||
| 40a232f3b2 | |||
| f589f49015 | |||
| b48b53e28a | |||
| a01f5c547a | |||
| f89be239fc | |||
| 8558b245be | |||
| 03e4997b05 | |||
| 05cdc4fde3 | |||
| 306ae182c1 | |||
| 410ea4d826 | |||
| 044ef38cbd | |||
| 15233b2d09 | |||
| 642a8eedce | |||
| c75b2aca5d | |||
| 1a25a0d85c | |||
| 29ac441c33 | |||
| 8fc5daf4d2 | |||
| bbecab908a | |||
| 4e2db97690 | |||
| e229c0ea44 | |||
| 3f865cf0dd | |||
| c13087a947 | |||
| 41afcd70ef | |||
| af2d6bb049 | |||
| 842155d887 | |||
| a242fe86ff | |||
| 4300f62951 | |||
| 861c6af76a | |||
| cd4cc614a6 | |||
| 2481138e00 | |||
| 43bce7ea55 | |||
| a6b6a04770 | |||
| 8f48025073 | |||
| 62b0f219dd | |||
| 37d0baea1e | |||
| a36e3413e1 | |||
| 6a2048b48e | |||
| 9b9c5c9d52 | |||
| f6c80a76b6 | |||
| ebce9f5f78 | |||
| 7d5da9613d | |||
| a0cce9f063 | |||
| 20b690bf62 | 
							
								
								
									
										2
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @ -7,3 +7,5 @@ gen | |||||||
| .idea/misc.xml | .idea/misc.xml | ||||||
| ncore-properties-local.xml | ncore-properties-local.xml | ||||||
| *.iml | *.iml | ||||||
|  | /out | ||||||
|  | dependencies.gradle | ||||||
							
								
								
									
										54
									
								
								.idea/codeStyles/Project.xml
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										54
									
								
								.idea/codeStyles/Project.xml
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @ -0,0 +1,54 @@ | |||||||
|  | <component name="ProjectCodeStyleConfiguration"> | ||||||
|  |   <code_scheme name="Project" version="173"> | ||||||
|  |     <option name="FORMATTER_TAGS_ENABLED" value="true" /> | ||||||
|  |     <JavaCodeStyleSettings> | ||||||
|  |       <option name="CLASS_COUNT_TO_USE_IMPORT_ON_DEMAND" value="999" /> | ||||||
|  |       <option name="NAMES_COUNT_TO_USE_IMPORT_ON_DEMAND" value="999" /> | ||||||
|  |       <option name="PACKAGES_TO_USE_IMPORT_ON_DEMAND"> | ||||||
|  |         <value /> | ||||||
|  |       </option> | ||||||
|  |       <option name="IMPORT_LAYOUT_TABLE"> | ||||||
|  |         <value> | ||||||
|  |           <package name="biz.redsoft" withSubpackages="true" static="false" /> | ||||||
|  |           <package name="biz.red_soft" withSubpackages="true" static="false" /> | ||||||
|  |           <emptyLine /> | ||||||
|  |           <package name="java" withSubpackages="true" static="false" /> | ||||||
|  |           <emptyLine /> | ||||||
|  |           <package name="javax" withSubpackages="true" static="false" /> | ||||||
|  |           <emptyLine /> | ||||||
|  |           <package name="org" withSubpackages="true" static="false" /> | ||||||
|  |           <emptyLine /> | ||||||
|  |           <package name="" withSubpackages="true" static="false" /> | ||||||
|  |           <emptyLine /> | ||||||
|  |           <package name="" withSubpackages="true" static="true" /> | ||||||
|  |         </value> | ||||||
|  |       </option> | ||||||
|  |     </JavaCodeStyleSettings> | ||||||
|  |     <codeStyleSettings language="JAVA"> | ||||||
|  |       <option name="KEEP_CONTROL_STATEMENT_IN_ONE_LINE" value="false" /> | ||||||
|  |       <option name="ALIGN_MULTILINE_PARAMETERS" value="false" /> | ||||||
|  |       <option name="CALL_PARAMETERS_WRAP" value="1" /> | ||||||
|  |       <option name="METHOD_PARAMETERS_WRAP" value="1" /> | ||||||
|  |       <option name="EXTENDS_LIST_WRAP" value="1" /> | ||||||
|  |       <option name="THROWS_LIST_WRAP" value="1" /> | ||||||
|  |       <option name="THROWS_KEYWORD_WRAP" value="1" /> | ||||||
|  |       <option name="METHOD_CALL_CHAIN_WRAP" value="1" /> | ||||||
|  |       <option name="BINARY_OPERATION_WRAP" value="1" /> | ||||||
|  |       <option name="TERNARY_OPERATION_WRAP" value="1" /> | ||||||
|  |       <option name="ARRAY_INITIALIZER_WRAP" value="1" /> | ||||||
|  |       <option name="ASSERT_STATEMENT_WRAP" value="1" /> | ||||||
|  |       <option name="VARIABLE_ANNOTATION_WRAP" value="2" /> | ||||||
|  |       <option name="ENUM_CONSTANTS_WRAP" value="2" /> | ||||||
|  |       <indentOptions> | ||||||
|  |         <option name="INDENT_SIZE" value="2" /> | ||||||
|  |         <option name="CONTINUATION_INDENT_SIZE" value="4" /> | ||||||
|  |       </indentOptions> | ||||||
|  |     </codeStyleSettings> | ||||||
|  |     <codeStyleSettings language="XML"> | ||||||
|  |       <indentOptions> | ||||||
|  |         <option name="INDENT_SIZE" value="2" /> | ||||||
|  |         <option name="CONTINUATION_INDENT_SIZE" value="4" /> | ||||||
|  |       </indentOptions> | ||||||
|  |     </codeStyleSettings> | ||||||
|  |   </code_scheme> | ||||||
|  | </component> | ||||||
							
								
								
									
										6
									
								
								.idea/codeStyles/codeStyleConfig.xml
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								.idea/codeStyles/codeStyleConfig.xml
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @ -0,0 +1,6 @@ | |||||||
|  | <component name="ProjectCodeStyleConfiguration"> | ||||||
|  |   <state> | ||||||
|  |     <option name="USE_PER_PROJECT_SETTINGS" value="true" /> | ||||||
|  |     <option name="PREFERRED_PROJECT_CODE_STYLE" value="Red" /> | ||||||
|  |   </state> | ||||||
|  | </component> | ||||||
							
								
								
									
										49
									
								
								.idea/compiler.xml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										49
									
								
								.idea/compiler.xml
									
									
									
										generated
									
									
									
								
							| @ -1,8 +1,6 @@ | |||||||
| <?xml version="1.0" encoding="UTF-8"?> | <?xml version="1.0" encoding="UTF-8"?> | ||||||
| <project version="4"> | <project version="4"> | ||||||
|   <component name="CompilerConfiguration"> |   <component name="CompilerConfiguration"> | ||||||
|     <option name="DEFAULT_COMPILER" value="Javac" /> |  | ||||||
|     <resourceExtensions /> |  | ||||||
|     <wildcardResourcePatterns> |     <wildcardResourcePatterns> | ||||||
|       <entry name="!?*.java" /> |       <entry name="!?*.java" /> | ||||||
|       <entry name="!?*.form" /> |       <entry name="!?*.form" /> | ||||||
| @ -14,9 +12,52 @@ | |||||||
|       <entry name="!?*.clj" /> |       <entry name="!?*.clj" /> | ||||||
|     </wildcardResourcePatterns> |     </wildcardResourcePatterns> | ||||||
|     <annotationProcessing> |     <annotationProcessing> | ||||||
|       <profile default="true" name="Default" enabled="false"> |       <profile name="Gradle Imported" enabled="true"> | ||||||
|         <processorPath useClasspath="true" /> |         <outputRelativeToContentRoot value="true" /> | ||||||
|  |         <processorPath useClasspath="false"> | ||||||
|  |           <entry name="$PROJECT_DIR$/../../../../../.gradle/caches/modules-2/files-2.1/biz.redsoft.ncore/ncoreAnnotationProcessor/1.0.5/ace0df7e3891cfc64042351df8616cf91e89c800/ncoreAnnotationProcessor-1.0.5.jar" /> | ||||||
|  |           <entry name="$PROJECT_DIR$/../../../../../.gradle/caches/modules-2/files-2.1/com.google.auto.service/auto-service/1.0.1/c9779f7372192a96c957a3df1faeeabd07881085/auto-service-1.0.1.jar" /> | ||||||
|  |           <entry name="$PROJECT_DIR$/../../../../../.gradle/caches/modules-2/files-2.1/com.fasterxml.jackson.core/jackson-core/2.13.4/cf934c681294b97ef6d80082faeefbe1edadf56/jackson-core-2.13.4.jar" /> | ||||||
|  |           <entry name="$PROJECT_DIR$/../../../../../.gradle/caches/modules-2/files-2.1/com.fasterxml.jackson.core/jackson-annotations/2.13.4/858c6cc78e1f08a885b1613e1d817c829df70a6e/jackson-annotations-2.13.4.jar" /> | ||||||
|  |           <entry name="$PROJECT_DIR$/../../../../../.gradle/caches/modules-2/files-2.1/com.fasterxml.jackson.core/jackson-databind/2.13.4/98b0edfa8e4084078f10b7b356c300ded4a71491/jackson-databind-2.13.4.jar" /> | ||||||
|  |           <entry name="$PROJECT_DIR$/../../../../../.gradle/caches/modules-2/files-2.1/com.google.auto.service/auto-service-annotations/1.0.1/ac86dacc0eb9285ea9d42eee6aad8629ca3a7432/auto-service-annotations-1.0.1.jar" /> | ||||||
|  |           <entry name="$PROJECT_DIR$/../../../../../.gradle/caches/modules-2/files-2.1/com.google.auto/auto-common/1.2/ca270191fd7d2a7297da7c8f29184206df10c67d/auto-common-1.2.jar" /> | ||||||
|  |           <entry name="$PROJECT_DIR$/../../../../../.gradle/caches/modules-2/files-2.1/com.google.guava/guava/31.0.1-jre/119ea2b2bc205b138974d351777b20f02b92704b/guava-31.0.1-jre.jar" /> | ||||||
|  |           <entry name="$PROJECT_DIR$/../../../../../.gradle/caches/modules-2/files-2.1/com.google.guava/failureaccess/1.0.1/1dcf1de382a0bf95a3d8b0849546c88bac1292c9/failureaccess-1.0.1.jar" /> | ||||||
|  |           <entry name="$PROJECT_DIR$/../../../../../.gradle/caches/modules-2/files-2.1/com.google.guava/listenablefuture/9999.0-empty-to-avoid-conflict-with-guava/b421526c5f297295adef1c886e5246c39d4ac629/listenablefuture-9999.0-empty-to-avoid-conflict-with-guava.jar" /> | ||||||
|  |           <entry name="$PROJECT_DIR$/../../../../../.gradle/caches/modules-2/files-2.1/com.google.code.findbugs/jsr305/3.0.2/25ea2e8b0c338a877313bd4672d3fe056ea78f0d/jsr305-3.0.2.jar" /> | ||||||
|  |           <entry name="$PROJECT_DIR$/../../../../../.gradle/caches/modules-2/files-2.1/org.checkerframework/checker-qual/3.12.0/d5692f0526415fcc6de94bb5bfbd3afd9dd3b3e5/checker-qual-3.12.0.jar" /> | ||||||
|  |           <entry name="$PROJECT_DIR$/../../../../../.gradle/caches/modules-2/files-2.1/com.google.errorprone/error_prone_annotations/2.7.1/458d9042f7aa6fa9a634df902b37f544e15aacac/error_prone_annotations-2.7.1.jar" /> | ||||||
|  |           <entry name="$PROJECT_DIR$/../../../../../.gradle/caches/modules-2/files-2.1/com.google.j2objc/j2objc-annotations/1.3/ba035118bc8bac37d7eff77700720999acd9986d/j2objc-annotations-1.3.jar" /> | ||||||
|  |         </processorPath> | ||||||
|  |         <module name="sample.main" /> | ||||||
|  |       </profile> | ||||||
|  |       <profile name="Gradle Imported" enabled="true"> | ||||||
|  |         <outputRelativeToContentRoot value="true" /> | ||||||
|  |         <processorPath useClasspath="false"> | ||||||
|  |           <entry name="$USER_HOME$/.gradle/caches/modules-2/files-2.1/biz.redsoft.ncore/ncoreAnnotationProcessor/1.0.10/52f347369a8b6f7467f9be747d42f1386c632c2c/ncoreAnnotationProcessor-1.0.10.jar" /> | ||||||
|  |           <entry name="$USER_HOME$/.gradle/caches/modules-2/files-2.1/com.google.auto.service/auto-service/1.0.1/c9779f7372192a96c957a3df1faeeabd07881085/auto-service-1.0.1.jar" /> | ||||||
|  |           <entry name="$MAVEN_REPOSITORY$/com/fasterxml/jackson/core/jackson-databind/2.13.4/jackson-databind-2.13.4.jar" /> | ||||||
|  |           <entry name="$MAVEN_REPOSITORY$/com/fasterxml/jackson/core/jackson-core/2.13.4/jackson-core-2.13.4.jar" /> | ||||||
|  |           <entry name="$USER_HOME$/.gradle/caches/modules-2/files-2.1/com.google.auto.service/auto-service-annotations/1.0.1/ac86dacc0eb9285ea9d42eee6aad8629ca3a7432/auto-service-annotations-1.0.1.jar" /> | ||||||
|  |           <entry name="$USER_HOME$/.gradle/caches/modules-2/files-2.1/com.google.auto/auto-common/1.2/ca270191fd7d2a7297da7c8f29184206df10c67d/auto-common-1.2.jar" /> | ||||||
|  |           <entry name="$MAVEN_REPOSITORY$/com/google/guava/guava/31.0.1-jre/guava-31.0.1-jre.jar" /> | ||||||
|  |           <entry name="$MAVEN_REPOSITORY$/com/fasterxml/jackson/core/jackson-annotations/2.13.4/jackson-annotations-2.13.4.jar" /> | ||||||
|  |           <entry name="$MAVEN_REPOSITORY$/com/google/guava/failureaccess/1.0.1/failureaccess-1.0.1.jar" /> | ||||||
|  |           <entry name="$MAVEN_REPOSITORY$/com/google/guava/listenablefuture/9999.0-empty-to-avoid-conflict-with-guava/listenablefuture-9999.0-empty-to-avoid-conflict-with-guava.jar" /> | ||||||
|  |           <entry name="$MAVEN_REPOSITORY$/com/google/code/findbugs/jsr305/3.0.2/jsr305-3.0.2.jar" /> | ||||||
|  |           <entry name="$MAVEN_REPOSITORY$/org/checkerframework/checker-qual/3.12.0/checker-qual-3.12.0.jar" /> | ||||||
|  |           <entry name="$MAVEN_REPOSITORY$/com/google/errorprone/error_prone_annotations/2.7.1/error_prone_annotations-2.7.1.jar" /> | ||||||
|  |           <entry name="$MAVEN_REPOSITORY$/com/google/j2objc/j2objc-annotations/1.3/j2objc-annotations-1.3.jar" /> | ||||||
|  |         </processorPath> | ||||||
|  |         <module name="biz.redsoft.sample.sample.main" /> | ||||||
|       </profile> |       </profile> | ||||||
|     </annotationProcessing> |     </annotationProcessing> | ||||||
|  |     <bytecodeTargetLevel> | ||||||
|  |       <module name="biz.redsoft.sample-sample" target="1.8" /> | ||||||
|  |       <module name="biz.redsoft.sample.sample" target="1.8" /> | ||||||
|  |       <module name="biz.redsoft.sample.sample.main" target="1.8" /> | ||||||
|  |       <module name="biz.redsoft.sample.sample.test" target="1.8" /> | ||||||
|  |     </bytecodeTargetLevel> | ||||||
|   </component> |   </component> | ||||||
| </project> | </project> | ||||||
							
								
								
									
										4
									
								
								.idea/gradle.xml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										4
									
								
								.idea/gradle.xml
									
									
									
										generated
									
									
									
								
							| @ -1,16 +1,16 @@ | |||||||
| <?xml version="1.0" encoding="UTF-8"?> | <?xml version="1.0" encoding="UTF-8"?> | ||||||
| <project version="4"> | <project version="4"> | ||||||
|  |   <component name="GradleMigrationSettings" migrationVersion="1" /> | ||||||
|   <component name="GradleSettings"> |   <component name="GradleSettings"> | ||||||
|     <option name="linkedExternalProjectsSettings"> |     <option name="linkedExternalProjectsSettings"> | ||||||
|       <GradleProjectSettings> |       <GradleProjectSettings> | ||||||
|         <option name="distributionType" value="DEFAULT_WRAPPED" /> |  | ||||||
|         <option name="externalProjectPath" value="$PROJECT_DIR$" /> |         <option name="externalProjectPath" value="$PROJECT_DIR$" /> | ||||||
|  |         <option name="gradleJvm" value="1.8" /> | ||||||
|         <option name="modules"> |         <option name="modules"> | ||||||
|           <set> |           <set> | ||||||
|             <option value="$PROJECT_DIR$" /> |             <option value="$PROJECT_DIR$" /> | ||||||
|           </set> |           </set> | ||||||
|         </option> |         </option> | ||||||
|         <option name="resolveModulePerSourceSet" value="false" /> |  | ||||||
|       </GradleProjectSettings> |       </GradleProjectSettings> | ||||||
|     </option> |     </option> | ||||||
|   </component> |   </component> | ||||||
|  | |||||||
							
								
								
									
										40
									
								
								.idea/jarRepositories.xml
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										40
									
								
								.idea/jarRepositories.xml
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @ -0,0 +1,40 @@ | |||||||
|  | <?xml version="1.0" encoding="UTF-8"?> | ||||||
|  | <project version="4"> | ||||||
|  |   <component name="RemoteRepositoriesConfiguration"> | ||||||
|  |     <remote-repository> | ||||||
|  |       <option name="id" value="central" /> | ||||||
|  |       <option name="name" value="Maven Central repository" /> | ||||||
|  |       <option name="url" value="https://repo1.maven.org/maven2" /> | ||||||
|  |     </remote-repository> | ||||||
|  |     <remote-repository> | ||||||
|  |       <option name="id" value="jboss.community" /> | ||||||
|  |       <option name="name" value="JBoss Community repository" /> | ||||||
|  |       <option name="url" value="https://repository.jboss.org/nexus/content/repositories/public/" /> | ||||||
|  |     </remote-repository> | ||||||
|  |     <remote-repository> | ||||||
|  |       <option name="id" value="MavenLocal" /> | ||||||
|  |       <option name="name" value="MavenLocal" /> | ||||||
|  |       <option name="url" value="file:/$MAVEN_REPOSITORY$/" /> | ||||||
|  |     </remote-repository> | ||||||
|  |     <remote-repository> | ||||||
|  |       <option name="id" value="maven" /> | ||||||
|  |       <option name="name" value="maven" /> | ||||||
|  |       <option name="url" value="http://nexus.red-soft.biz/repository/public" /> | ||||||
|  |     </remote-repository> | ||||||
|  |     <remote-repository> | ||||||
|  |       <option name="id" value="maven" /> | ||||||
|  |       <option name="name" value="maven" /> | ||||||
|  |       <option name="url" value="https://nexus.red-soft.ru/repository/public" /> | ||||||
|  |     </remote-repository> | ||||||
|  |     <remote-repository> | ||||||
|  |       <option name="id" value="maven3" /> | ||||||
|  |       <option name="name" value="maven3" /> | ||||||
|  |       <option name="url" value="https://ncore-repo.red-soft.ru/repository/public" /> | ||||||
|  |     </remote-repository> | ||||||
|  |     <remote-repository> | ||||||
|  |       <option name="id" value="MavenLocal" /> | ||||||
|  |       <option name="name" value="MavenLocal" /> | ||||||
|  |       <option name="url" value="file:$MAVEN_REPOSITORY$/" /> | ||||||
|  |     </remote-repository> | ||||||
|  |   </component> | ||||||
|  | </project> | ||||||
							
								
								
									
										6
									
								
								.idea/modules.xml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										6
									
								
								.idea/modules.xml
									
									
									
										generated
									
									
									
								
							| @ -2,7 +2,11 @@ | |||||||
| <project version="4"> | <project version="4"> | ||||||
|   <component name="ProjectModuleManager"> |   <component name="ProjectModuleManager"> | ||||||
|     <modules> |     <modules> | ||||||
|       <module fileurl="file://$PROJECT_DIR$/sample.iml" filepath="$PROJECT_DIR$/sample.iml" /> |       <module fileurl="file://$PROJECT_DIR$/.idea/modules/biz.redsoft.sample-sample.iml" filepath="$PROJECT_DIR$/.idea/modules/biz.redsoft.sample-sample.iml" group="sample" /> | ||||||
|  |       <module fileurl="file://$PROJECT_DIR$/.idea/modules/biz.redsoft.sample.sample.iml" filepath="$PROJECT_DIR$/.idea/modules/biz.redsoft.sample.sample.iml" /> | ||||||
|  |       <module fileurl="file://$PROJECT_DIR$/.idea/modules/biz.redsoft.sample.sample.main.iml" filepath="$PROJECT_DIR$/.idea/modules/biz.redsoft.sample.sample.main.iml" /> | ||||||
|  |       <module fileurl="file://$PROJECT_DIR$/.idea/modules/biz.redsoft.sample.sample.test.iml" filepath="$PROJECT_DIR$/.idea/modules/biz.redsoft.sample.sample.test.iml" /> | ||||||
|  |       <module fileurl="file://$PROJECT_DIR$/.idea/modules/sample.main.iml" filepath="$PROJECT_DIR$/.idea/modules/sample.main.iml" /> | ||||||
|     </modules> |     </modules> | ||||||
|   </component> |   </component> | ||||||
| </project> | </project> | ||||||
							
								
								
									
										17
									
								
								.idea/runConfigurations/MainForm.xml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										17
									
								
								.idea/runConfigurations/MainForm.xml
									
									
									
										generated
									
									
									
								
							| @ -1,16 +1,13 @@ | |||||||
| <component name="ProjectRunConfigurationManager"> | <component name="ProjectRunConfigurationManager"> | ||||||
|   <configuration default="false" name="MainForm" type="Application" factoryName="Application"> |   <configuration default="false" name="MainForm" type="Application" factoryName="Application"> | ||||||
|     <extension name="coverage" enabled="false" merge="false" sample_coverage="true" runner="idea" /> |     <option name="ALTERNATIVE_JRE_PATH" value="1.8 (2)" /> | ||||||
|  |     <option name="ALTERNATIVE_JRE_PATH_ENABLED" value="true" /> | ||||||
|     <option name="MAIN_CLASS_NAME" value="biz.redsoft.ncore.client.MainForm" /> |     <option name="MAIN_CLASS_NAME" value="biz.redsoft.ncore.client.MainForm" /> | ||||||
|     <option name="VM_PARAMETERS" value="-Dlog4j.console.encoding=UTF-8" /> |     <module name="sample.main" /> | ||||||
|     <option name="PROGRAM_PARAMETERS" value="-config ncore-properties.xml -config ncore-properties-local.xml" /> |     <option name="PROGRAM_PARAMETERS" value="-config ncore-properties.xml -config ncore-properties-local.xml" /> | ||||||
|     <option name="WORKING_DIRECTORY" value="file://$PROJECT_DIR$" /> |     <option name="VM_PARAMETERS" value="-Dlog.console.encoding=UTF-8" /> | ||||||
|     <option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" /> |     <method v="2"> | ||||||
|     <option name="ALTERNATIVE_JRE_PATH" /> |       <option name="Make" enabled="true" /> | ||||||
|     <option name="ENABLE_SWING_INSPECTOR" value="false" /> |     </method> | ||||||
|     <option name="ENV_VARIABLES" /> |  | ||||||
|     <option name="PASS_PARENT_ENVS" value="true" /> |  | ||||||
|     <envs /> |  | ||||||
|     <method /> |  | ||||||
|   </configuration> |   </configuration> | ||||||
| </component> | </component> | ||||||
							
								
								
									
										10
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								README.md
									
									
									
									
									
								
							| @ -5,7 +5,7 @@ | |||||||
|  |  | ||||||
| Для данного проекта можно использовать базу ядра. | Для данного проекта можно использовать базу ядра. | ||||||
|  |  | ||||||
| Таски запускаются с помощью gradle wrapper. Версия Gradle - 4.10.3. | Таски запускаются с помощью gradle wrapper. Версия Gradle - 7.6.4. | ||||||
|  |  | ||||||
| Nix | Nix | ||||||
| ```bash | ```bash | ||||||
| @ -20,6 +20,7 @@ gradlew.bat build | |||||||
|  |  | ||||||
| ### Основные таски | ### Основные таски | ||||||
|  |  | ||||||
|  | * ncoreRestoreDatabase (или nRDB) - восстановление базы из бекапа | ||||||
| * ncoreLoadPatches (или patch) - загрузка патчей | * ncoreLoadPatches (или patch) - загрузка патчей | ||||||
| * ncoreApplyPatches (или update) - применение патчей | * ncoreApplyPatches (или update) - применение патчей | ||||||
| * ncoreUpdateDb (или updateDatabase) - загрузка и применение патчей | * ncoreUpdateDb (или updateDatabase) - загрузка и применение патчей | ||||||
| @ -34,6 +35,11 @@ gradlew.bat build | |||||||
|  |  | ||||||
| Если нужно выполнить таск, но при этом не выполнять определенные такси из его зависимостей, то можно воспользоваться ключом -x. | Если нужно выполнить таск, но при этом не выполнять определенные такси из его зависимостей, то можно воспользоваться ключом -x. | ||||||
|  |  | ||||||
|  | Запуск проекта одной командой: | ||||||
|  | ```bash | ||||||
|  | ./gradlew nRDB build run | ||||||
|  | ``` | ||||||
|  |  | ||||||
| Компиляция классов: | Компиляция классов: | ||||||
| ```bash | ```bash | ||||||
| ./gradlew classes -x generateSources | ./gradlew classes -x generateSources | ||||||
| @ -100,7 +106,7 @@ rootProject.name = 'biz.redsoft.myproject' | |||||||
|  |  | ||||||
| 9. Актуальная версия ядра указывается в файле gradle.properties: | 9. Актуальная версия ядра указывается в файле gradle.properties: | ||||||
| ``` | ``` | ||||||
| biz.redsoft.ncore.version=1.6.69.0 | biz.redsoft.ncore.version=1.10.339.9 | ||||||
| ``` | ``` | ||||||
| Запуск толстого клиента осуществляется в собранном дистрибутиве (distTar или distZip) в каталоге bin командой: | Запуск толстого клиента осуществляется в собранном дистрибутиве (distTar или distZip) в каталоге bin командой: | ||||||
| start-client.bat (или ./start-client в линуксе) | start-client.bat (или ./start-client в линуксе) | ||||||
|  | |||||||
							
								
								
									
										140
									
								
								build.gradle
									
									
									
									
									
								
							
							
						
						
									
										140
									
								
								build.gradle
									
									
									
									
									
								
							| @ -1,33 +1,36 @@ | |||||||
| buildscript { | plugins { | ||||||
|     repositories { |     id 'nu.studer.credentials' version('1.0.7') | ||||||
|         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:+' |     id 'war' | ||||||
|         classpath 'nu.studer:gradle-credentials-plugin:1.0.4' |     id 'gradle-ncore' version("$pluginVersion") | ||||||
|     } |     id 'maven-publish' | ||||||
| } | } | ||||||
|  |  | ||||||
| group = 'biz.redsoft.sample' | java { | ||||||
|  |     withSourcesJar() | ||||||
|  |     sourceCompatibility = project.properties.'java.version' ?: 17 | ||||||
|  | } | ||||||
|  |  | ||||||
| apply plugin: 'nu.studer.credentials' | test { | ||||||
| apply plugin: 'idea' |     failOnNoDiscoveredTests = false | ||||||
| apply plugin: 'application' | } | ||||||
| apply plugin: 'war' |  | ||||||
| apply plugin: 'ncore' |  | ||||||
|  |  | ||||||
| targetCompatibility = 1.8 |  | ||||||
|  |  | ||||||
| ncore { | ncore { | ||||||
|     coreVersion = project.properties.'biz.redsoft.ncore.version' |     coreVersion = project.properties.'biz.redsoft.ncore.version' | ||||||
|     sourceEncoding = 'UTF-8' |     sourceEncoding = 'UTF-8' | ||||||
| } | } | ||||||
|  |  | ||||||
|  | group = 'biz.redsoft.sample' | ||||||
|  |  | ||||||
| repositories { | repositories { | ||||||
|     mavenLocal() |  | ||||||
|     maven { |     maven { | ||||||
|         url 'http://nexus.red-soft.biz/repository/public' |         def repo = getProperty("biz.redsoft.private.repo") | ||||||
|  |         url  repo | ||||||
|  |         if (repo.contains("http:/")) | ||||||
|  |             allowInsecureProtocol = true | ||||||
|         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,11 +41,15 @@ repositories { | |||||||
| } | } | ||||||
|  |  | ||||||
| dependencies { | dependencies { | ||||||
|     provided 'javax.servlet:javax.servlet-api:3.1.0' |     testCompileOnly 'org.junit.jupiter:junit-jupiter:5.8.2' | ||||||
|  |     testImplementation 'org.apache.tomcat.embed:tomcat-embed-core:9.0.76' | ||||||
|     testCompile 'junit:junit:4.+' |     testImplementation 'org.apache.tomcat.embed:tomcat-embed-jasper:9.0.76' | ||||||
|  |     runtimeOnly files(ncoreGenerateControlDataJar) | ||||||
|  |     runtimeOnly files(genJar) | ||||||
|  |     implementation("jakarta.servlet:jakarta.servlet-api:5.0.0") | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| // 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') | ||||||
| @ -50,7 +57,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() { | ||||||
| @ -66,12 +77,13 @@ gradle.services.get(LoggingOutputInternal).addStandardErrorListener (new Standar | |||||||
| }) | }) | ||||||
| // --------------------- BUILD LOG SETTINGS ---------------------- | // --------------------- BUILD LOG SETTINGS ---------------------- | ||||||
|  |  | ||||||
| run.args = ['client', | run.args += ['client', | ||||||
|             '-config', 'ncore-properties.xml', |             '-config', 'ncore-properties.xml', | ||||||
|             '-config', 'ncore-properties-local.xml'] |             '-config', 'ncore-properties-local.xml'] | ||||||
|  |  | ||||||
| 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')) | ||||||
| @ -81,12 +93,84 @@ 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' |     def newVersion = project.getVersion().toString().replace("-SNAPSHOT", "") | ||||||
|  |     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${newVersion}" | ||||||
|  |     versionPropertyFile = versionPropertiesFilePath | ||||||
|  |     versionProperties = [] | ||||||
|  |     snapshotSuffix = '-SNAPSHOT' | ||||||
|  |     buildTasks = ['ncoreTestDbConnection', 'clean', 'unSnapshotVersion', 'writeVersion', 'commitNewVersion', 'nbackup', 'build', 'copyDist', 'publish', 'dockerFile', 'commitNewVersion'] | ||||||
|  |     ignoredSnapshotDependencies = [] | ||||||
|  |     versionPatterns = [ | ||||||
|  |             /(\d+)(\.)(\d+)(\.)(\d+)([^\d]*\u0024)/: { Matcher m, Project p -> | ||||||
|  |                 project.getVersion().newVersion().toString() | ||||||
|  |             } | ||||||
|  |     ] | ||||||
|  |     git.requireBranch.set('master') | ||||||
|  |     pushReleaseVersionBranch = 'master' | ||||||
| } | } | ||||||
|  |  | ||||||
| task buildRelease(type: GradleBuild) { | //Добавить флаг -Pbiz.redsoft.release=true к таске release для того чтобы публиковалось в releases и false если в snapshots. | ||||||
|     tasks = ['clean', 'writeVersion', 'nbackup', 'build', 'copyDist', 'publish'] | //./gradlew release -Pbiz.redsoft.release=true  | ||||||
|  | publishing { | ||||||
|  |     repositories { | ||||||
|  |         maven { | ||||||
|  |             def isRepoCredetionals = project.hasProperty('biz.redsoft.repo.user') && project.hasProperty('biz.redsoft.repo.password') | ||||||
|  |             def isCredentialsInsideBuildScript = project.credentials.user != null && project.credentials.password != null | ||||||
|  |             println(isRepoCredetionals ? "Using repoCredentials for publish..." : | ||||||
|  |                     isCredentialsInsideBuildScript ? "Using buildScript credentials for publish..." : "Credentials are not presented!!!") | ||||||
|  |             if (isRepoCredetionals) { | ||||||
|  |                 credentials { | ||||||
|  |                     username project.'biz.redsoft.repo.user' | ||||||
|  |                     password project.'biz.redsoft.repo.password' | ||||||
|  |                 } | ||||||
|  |             } else if (isCredentialsInsideBuildScript) { | ||||||
|  |                 credentials { | ||||||
|  |                     username project.credentials.user | ||||||
|  |                     password project.credentials.password | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |             def suffix = project.findProperty('biz.redsoft.release') ? 'releases' : 'snapshots' | ||||||
|  |             url "https://ncore-repo.red-soft.ru/repository/${suffix}" | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |     publications { | ||||||
|  |         mavenJava(MavenPublication) { | ||||||
|  |             from components.java | ||||||
|  |         } | ||||||
|  |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| 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 | ||||||
|  | } | ||||||
							
								
								
									
										
											BIN
										
									
								
								db/ncore.7z
									
									
									
									
									
								
							
							
						
						
									
										
											BIN
										
									
								
								db/ncore.7z
									
									
									
									
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								db/ncore.zip
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								db/ncore.zip
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										10
									
								
								dependencies.gradle
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								dependencies.gradle
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,10 @@ | |||||||
|  | dependencies { | ||||||
|  |   implementation("biz.redsoft.ncore:ncore-JDK17:1.10.339.68") | ||||||
|  |   updates("biz.redsoft.ncore:ncore-JDK17:1.10.339.68:updates") | ||||||
|  |   codemaker("biz.redsoft.ncore:ncore-JDK17:1.10.339.68") | ||||||
|  |   implementation("biz.redsoft.ncore:ncore-util-JDK17:1.10.339.68") | ||||||
|  |   implementation("biz.redsoft.ncore:ncore-cryptoapisec-JDK17:1.10.339.68") | ||||||
|  |   implementation("biz.redsoft.ncore:ncore-jna-JDK17:1.10.339.68") | ||||||
|  |   codemaker("biz.redsoft.ncore:ncore-JDK17:1.10.339.68:gen") | ||||||
|  |   testImplementation("biz.redsoft.ncore:ncore-JDK17:1.10.339.68:tests") | ||||||
|  | } | ||||||
| @ -1 +1,7 @@ | |||||||
| biz.redsoft.ncore.version=1.6.92.1 | biz.redsoft.ncore.version=1.10.339.68 | ||||||
|  | org.gradle.jvmargs=-Xmx4g -XX:+HeapDumpOnOutOfMemoryError | ||||||
|  | org.gradle.daemon=false | ||||||
|  | org.gradle.configureondemand=true | ||||||
|  | pluginVersion=4.0.18 | ||||||
|  | biz.redsoft.public.repo=https://ncore-repo.red-soft.ru/repository/public | ||||||
|  | biz.redsoft.private.repo=https://ncore-repo.red-soft.ru/repository/ncorez | ||||||
							
								
								
									
										
											BIN
										
									
								
								gradle/wrapper/gradle-wrapper.jar
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										
											BIN
										
									
								
								gradle/wrapper/gradle-wrapper.jar
									
									
									
									
										vendored
									
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										3
									
								
								gradle/wrapper/gradle-wrapper.properties
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								gradle/wrapper/gradle-wrapper.properties
									
									
									
									
										vendored
									
									
								
							| @ -1,6 +1,5 @@ | |||||||
| #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-9.0.0-bin.zip | ||||||
| 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 |  | ||||||
|  | |||||||
							
								
								
									
										22
									
								
								gradlew
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										22
									
								
								gradlew
									
									
									
									
										vendored
									
									
								
							| @ -1,4 +1,4 @@ | |||||||
| #!/usr/bin/env bash | #!/usr/bin/env sh | ||||||
|  |  | ||||||
| ############################################################################## | ############################################################################## | ||||||
| ## | ## | ||||||
| @ -154,11 +154,19 @@ if $cygwin ; then | |||||||
|     esac |     esac | ||||||
| fi | fi | ||||||
|  |  | ||||||
| # Split up the JVM_OPTS And GRADLE_OPTS values into an array, following the shell quoting and substitution rules | # Escape application args | ||||||
| function splitJvmOpts() { | save () { | ||||||
|     JVM_OPTS=("$@") |     for i do printf %s\\n "$i" | sed "s/'/'\\\\''/g;1s/^/'/;\$s/\$/' \\\\/" ; done | ||||||
|  |     echo " " | ||||||
| } | } | ||||||
| eval splitJvmOpts $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS | APP_ARGS=$(save "$@") | ||||||
| JVM_OPTS[${#JVM_OPTS[*]}]="-Dorg.gradle.appname=$APP_BASE_NAME" |  | ||||||
|  |  | ||||||
| exec "$JAVACMD" "${JVM_OPTS[@]}" -classpath "$CLASSPATH" org.gradle.wrapper.GradleWrapperMain "$@" | # Collect all arguments for the java command, following the shell quoting and substitution rules | ||||||
|  | eval set -- $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS "\"-Dorg.gradle.appname=$APP_BASE_NAME\"" -classpath "\"$CLASSPATH\"" org.gradle.wrapper.GradleWrapperMain "$APP_ARGS" | ||||||
|  |  | ||||||
|  | # by default we should be in the correct project dir, but when run from Finder on Mac, the cwd is wrong | ||||||
|  | if [ "$(uname)" = "Darwin" ] && [ "$HOME" = "$PWD" ]; then | ||||||
|  |   cd "$(dirname "$0")" | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | exec "$JAVACMD" "$@" | ||||||
|  | |||||||
							
								
								
									
										6
									
								
								gradlew.bat
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								gradlew.bat
									
									
									
									
										vendored
									
									
								
							| @ -49,7 +49,6 @@ goto fail | |||||||
| @rem Get command-line arguments, handling Windows variants | @rem Get command-line arguments, handling Windows variants | ||||||
|  |  | ||||||
| if not "%OS%" == "Windows_NT" goto win9xME_args | if not "%OS%" == "Windows_NT" goto win9xME_args | ||||||
| if "%@eval[2+2]" == "4" goto 4NT_args |  | ||||||
|  |  | ||||||
| :win9xME_args | :win9xME_args | ||||||
| @rem Slurp the command line arguments. | @rem Slurp the command line arguments. | ||||||
| @ -60,11 +59,6 @@ set _SKIP=2 | |||||||
| if "x%~1" == "x" goto execute | if "x%~1" == "x" goto execute | ||||||
|  |  | ||||||
| set CMD_LINE_ARGS=%* | 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 | ||||||
|  | |||||||
| @ -1,26 +0,0 @@ | |||||||
| log4j.rootLogger=DEBUG, file, stdout |  | ||||||
| log4j.logger.biz.redsoft.ncore.docflow.Log4jDocFlowLogger=INFO, biz.redsoft.ncore.docflow.Log4jDocFlowLogger |  | ||||||
|  |  | ||||||
| log4j.appender.biz.redsoft.ncore.docflow.Log4jDocFlowLogger=org.apache.log4j.FileAppender |  | ||||||
| log4j.appender.biz.redsoft.ncore.docflow.Log4jDocFlowLogger.layout=org.apache.log4j.PatternLayout |  | ||||||
| log4j.appender.biz.redsoft.ncore.docflow.Log4jDocFlowLogger.layout.ConversionPattern=%d{dd.MM.yy HH:mm:ss.SSS},%t,%p,%c{1},%m%n |  | ||||||
| #log4j.appender.biz.redsoft.ncore.docflow.Log4jDocFlowLogger.encoding=UTF-8 |  | ||||||
| log4j.appender.biz.redsoft.ncore.docflow.Log4jDocFlowLogger.File=logs/docflow.log |  | ||||||
|  |  | ||||||
| log4j.appender.stdout=org.apache.log4j.ConsoleAppender |  | ||||||
| log4j.appender.stdout.layout=org.apache.log4j.PatternLayout |  | ||||||
| log4j.appender.stdout.layout.ConversionPattern=%d{dd.MM.yy HH:mm:ss.SSS},%t,%p,%c{1},%m%n |  | ||||||
| #log4j.appender.stdout.encoding=UTF-8 |  | ||||||
|  |  | ||||||
| log4j.appender.stdout.Threshold=DEBUG |  | ||||||
|  |  | ||||||
| log4j.appender.file=org.apache.log4j.FileAppender |  | ||||||
| log4j.appender.file.layout=org.apache.log4j.PatternLayout |  | ||||||
| log4j.appender.file.layout.ConversionPattern=%d{dd.MM.yy HH:mm:ss.SSS},%t,%p,%c{1},%m%n |  | ||||||
| log4j.appender.file.encoding=UTF-8 |  | ||||||
| log4j.appender.file.Threshold=INFO |  | ||||||
|  |  | ||||||
|  |  | ||||||
| log4j.appender.file.File=logs/ncore.log |  | ||||||
| log4j.appender.file.Append=true |  | ||||||
|   |  | ||||||
							
								
								
									
										26
									
								
								logback.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								logback.xml
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,26 @@ | |||||||
|  | <?xml version="1.0" encoding="UTF-8"?> | ||||||
|  | <configuration> | ||||||
|  |   <define name="consoleEncoding" class="biz.redsoft.util.logback.ConsoleEncoding"/> | ||||||
|  |  | ||||||
|  |   <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender"> | ||||||
|  |     <encoder> | ||||||
|  |       <charset>${consoleEncoding}</charset> | ||||||
|  |       <pattern>%d{dd.MM.yy HH:mm:ss.SSS} [%t] %p %c{0} - %m%n</pattern> | ||||||
|  |     </encoder> | ||||||
|  |   </appender> | ||||||
|  |  | ||||||
|  |   <appender name="FILE" class="ch.qos.logback.core.FileAppender"> | ||||||
|  |     <file>logs/ncore.log</file> | ||||||
|  |     <append>true</append> | ||||||
|  |     <immediateFlush>true</immediateFlush> | ||||||
|  |     <encoder> | ||||||
|  |       <charset>UTF-8</charset> | ||||||
|  |       <pattern>%d{dd.MM.yy HH:mm:ss.SSS} [%t] %p %c{0} - %m%n</pattern> | ||||||
|  |     </encoder> | ||||||
|  |   </appender> | ||||||
|  |  | ||||||
|  |   <root level="debug"> | ||||||
|  |     <appender-ref ref="STDOUT" /> | ||||||
|  |     <appender-ref ref="FILE" /> | ||||||
|  |   </root> | ||||||
|  | </configuration> | ||||||
| @ -3,4 +3,9 @@ | |||||||
| <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--> | ||||||
|  |   <!-- На линуксе файл должен быть доступен группе firbird/reddatabase!!! --> | ||||||
|  |   <entry key="ncore.db.backup.path">db/ncore.zip</entry> | ||||||
|  |   <!-- На линуксе файл должен быть доступен группе firbird/reddatabase!!! --> | ||||||
|  |   <entry key="ncore.db.restore.path">/db/ncore-sample.fdb</entry> | ||||||
| </properties> | </properties> | ||||||
|  | |||||||
| @ -1 +1,13 @@ | |||||||
|  | pluginManagement{ | ||||||
|  |     repositories { | ||||||
|  |         mavenLocal() | ||||||
|  |         maven { | ||||||
|  |             def repo = getProperty("biz.redsoft.public.repo") | ||||||
|  |             url  repo | ||||||
|  |             if (repo.contains("http:/")) | ||||||
|  |                 allowInsecureProtocol = true | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
| 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/sample $1 -config config/ncore-properties.xml -logconfig config/log4j.properties $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\.." | ||||||
| bin\sample.bat %1 -config config\ncore-properties.xml -logconfig config\log4j.properties %2 %3 %4 %5 | call bin\sample.bat %1 -config config\ncore-properties.xml %2 %3 %4 %5 | ||||||
| popd | popd | ||||||
							
								
								
									
										15
									
								
								src/dist/bin/sync-full
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								src/dist/bin/sync-full
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,15 @@ | |||||||
|  | #!/bin/bash | ||||||
|  |  | ||||||
|  | $(dirname $0)/starter patch updates | ||||||
|  |  | ||||||
|  | if [ $? -ne 0 ] ; then  | ||||||
|  |     echo Error patch loading | ||||||
|  |     exit 10 | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | $(dirname $0)/starter update -fullSync | ||||||
|  |  | ||||||
|  | if [ $? -ne 0 ] ; then  | ||||||
|  |     echo Error updating database | ||||||
|  |     exit 11 | ||||||
|  | fi | ||||||
							
								
								
									
										7
									
								
								src/dist/bin/sync-full.bat
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								src/dist/bin/sync-full.bat
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,7 @@ | |||||||
|  | @echo off | ||||||
|  |  | ||||||
|  | call "%~dp0\starter.bat" patch updates | ||||||
|  | if ERRORLEVEL == 1 goto :EOF | ||||||
|  |  | ||||||
|  | call "%~dp0\starter.bat" update -fullSync | ||||||
|  | @pause | ||||||
							
								
								
									
										24
									
								
								src/dist/config/log4j.properties
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										24
									
								
								src/dist/config/log4j.properties
									
									
									
									
										vendored
									
									
								
							| @ -1,24 +0,0 @@ | |||||||
| log4j.rootLogger=ERROR, file, stdout |  | ||||||
| log4j.logger.biz.redsoft.ncore.docflow.Log4jDocFlowLogger=ERROR, biz.redsoft.ncore.docflow.Log4jDocFlowLogger |  | ||||||
|  |  | ||||||
| log4j.appender.biz.redsoft.ncore.docflow.Log4jDocFlowLogger=org.apache.log4j.FileAppender |  | ||||||
| log4j.appender.biz.redsoft.ncore.docflow.Log4jDocFlowLogger.layout=org.apache.log4j.PatternLayout |  | ||||||
| log4j.appender.biz.redsoft.ncore.docflow.Log4jDocFlowLogger.layout.ConversionPattern=%d{dd.MM.yy HH:mm:ss.SSS},%t,%p,%c{1},%m%n |  | ||||||
| log4j.appender.biz.redsoft.ncore.docflow.Log4jDocFlowLogger.encoding=UTF-8 |  | ||||||
| log4j.appender.biz.redsoft.ncore.docflow.Log4jDocFlowLogger.File=${server.home}/logs/sample-docflow.log |  | ||||||
|  |  | ||||||
| log4j.appender.stdout=org.apache.log4j.ConsoleAppender |  | ||||||
| log4j.appender.stdout.layout=org.apache.log4j.PatternLayout |  | ||||||
| log4j.appender.stdout.layout.ConversionPattern=%d{dd.MM.yy HH:mm:ss.SSS},%t,%p,%c{1},%m%n |  | ||||||
| log4j.appender.stdout.encoding=UTF-8 |  | ||||||
|  |  | ||||||
| log4j.appender.stdout.Threshold=FATAL |  | ||||||
|  |  | ||||||
| log4j.appender.file=org.apache.log4j.FileAppender |  | ||||||
| log4j.appender.file.layout=org.apache.log4j.PatternLayout |  | ||||||
| log4j.appender.file.layout.ConversionPattern=%d{dd.MM.yy HH:mm:ss.SSS},%t,%p,%c{1},%m%n |  | ||||||
| log4j.appender.file.encoding=UTF-8 |  | ||||||
| log4j.appender.file.Threshold=ERROR |  | ||||||
|  |  | ||||||
| log4j.appender.file.File=${server.home}/logs/ncore-sample.log |  | ||||||
| log4j.appender.file.Append=true |  | ||||||
							
								
								
									
										26
									
								
								src/dist/config/logback.xml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								src/dist/config/logback.xml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,26 @@ | |||||||
|  | <?xml version="1.0" encoding="UTF-8"?> | ||||||
|  | <configuration> | ||||||
|  |   <define name="consoleEncoding" class="biz.redsoft.util.logback.ConsoleEncoding"/> | ||||||
|  |  | ||||||
|  |   <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender"> | ||||||
|  |     <encoder> | ||||||
|  |       <charset>${consoleEncoding}</charset> | ||||||
|  |       <pattern>%d{dd.MM.yy HH:mm:ss.SSS} [%t] %p %c{0} - %m%n</pattern> | ||||||
|  |     </encoder> | ||||||
|  |   </appender> | ||||||
|  |  | ||||||
|  |   <appender name="FILE" class="ch.qos.logback.core.FileAppender"> | ||||||
|  |     <file>logs/ncore.log</file> | ||||||
|  |     <append>true</append> | ||||||
|  |     <immediateFlush>true</immediateFlush> | ||||||
|  |     <encoder> | ||||||
|  |       <charset>UTF-8</charset> | ||||||
|  |       <pattern>%d{dd.MM.yy HH:mm:ss.SSS} [%t] %p %c{0} - %m%n</pattern> | ||||||
|  |     </encoder> | ||||||
|  |   </appender> | ||||||
|  |  | ||||||
|  |   <root level="debug"> | ||||||
|  |     <appender-ref ref="STDOUT" /> | ||||||
|  |     <appender-ref ref="FILE" /> | ||||||
|  |   </root> | ||||||
|  | </configuration> | ||||||
| @ -4,9 +4,7 @@ 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(); | ||||||
|  |  | ||||||
|  | |||||||
| @ -2,17 +2,16 @@ package biz.redsoft.sample; | |||||||
|  |  | ||||||
| import biz.redsoft.util.IncorrectVersionFormat; | import biz.redsoft.util.IncorrectVersionFormat; | ||||||
| import biz.redsoft.util.VersionUtils; | import biz.redsoft.util.VersionUtils; | ||||||
| import org.apache.log4j.Logger; |  | ||||||
|  |  | ||||||
| import java.io.IOException; | import java.io.IOException; | ||||||
| import java.io.InputStream; | import java.io.InputStream; | ||||||
| import java.util.Properties; | import java.util.Properties; | ||||||
|  |  | ||||||
| /** | import org.slf4j.Logger; | ||||||
|  * @author Victor Bellavin | import org.slf4j.LoggerFactory; | ||||||
|  */ |  | ||||||
| public class Version { | public class Version { | ||||||
|     public static final Logger LOGGER = Logger.getLogger(Version.class); |     public static final Logger LOGGER = LoggerFactory.getLogger(Version.class); | ||||||
|  |  | ||||||
|     public static final String VERSION_FILE = "version.properties"; |     public static final String VERSION_FILE = "version.properties"; | ||||||
|     public static final String VERSION_PROP_NAME = "version"; |     public static final String VERSION_PROP_NAME = "version"; | ||||||
| @ -36,7 +35,7 @@ public class Version { | |||||||
|         if (is != null) { |         if (is != null) { | ||||||
|             loadVersion(version, is); |             loadVersion(version, is); | ||||||
|         } else { |         } else { | ||||||
|             LOGGER.warn("No version resource at " + versionPath + " Trying to load it from the main package..."); |             LOGGER.warn("No version resource at {} Trying to load it from the main package...", versionPath); | ||||||
|             final InputStream oldStream = Version.class.getResourceAsStream(VERSION_FILE); |             final InputStream oldStream = Version.class.getResourceAsStream(VERSION_FILE); | ||||||
|             if (oldStream != null) |             if (oldStream != null) | ||||||
|                 loadVersion(version, oldStream); |                 loadVersion(version, oldStream); | ||||||
|  | |||||||
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 953 B | 
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 1016 B | 
| @ -1,24 +0,0 @@ | |||||||
| log4j.rootLogger=ERROR, file, stdout |  | ||||||
| log4j.logger.biz.redsoft.ncore.docflow.Log4jDocFlowLogger=ERROR, biz.redsoft.ncore.docflow.Log4jDocFlowLogger |  | ||||||
|  |  | ||||||
| log4j.appender.biz.redsoft.ncore.docflow.Log4jDocFlowLogger=org.apache.log4j.FileAppender |  | ||||||
| log4j.appender.biz.redsoft.ncore.docflow.Log4jDocFlowLogger.layout=org.apache.log4j.PatternLayout |  | ||||||
| log4j.appender.biz.redsoft.ncore.docflow.Log4jDocFlowLogger.layout.ConversionPattern=%d{dd.MM.yy HH:mm:ss.SSS},%t,%p,%c{1},%m%n |  | ||||||
| log4j.appender.biz.redsoft.ncore.docflow.Log4jDocFlowLogger.encoding=UTF-8 |  | ||||||
| log4j.appender.biz.redsoft.ncore.docflow.Log4jDocFlowLogger.File=${server.home}/logs/sample-docflow.log |  | ||||||
|  |  | ||||||
| log4j.appender.stdout=org.apache.log4j.ConsoleAppender |  | ||||||
| log4j.appender.stdout.layout=org.apache.log4j.PatternLayout |  | ||||||
| log4j.appender.stdout.layout.ConversionPattern=%d{dd.MM.yy HH:mm:ss.SSS},%t,%p,%c{1},%m%n |  | ||||||
| log4j.appender.stdout.encoding=UTF-8 |  | ||||||
|  |  | ||||||
| log4j.appender.stdout.Threshold=ERROR |  | ||||||
|  |  | ||||||
| log4j.appender.file=org.apache.log4j.FileAppender |  | ||||||
| log4j.appender.file.layout=org.apache.log4j.PatternLayout |  | ||||||
| log4j.appender.file.layout.ConversionPattern=%d{dd.MM.yy HH:mm:ss.SSS},%t,%p,%c{1},%m%n |  | ||||||
| log4j.appender.file.encoding=UTF-8 |  | ||||||
| log4j.appender.file.Threshold=ERROR |  | ||||||
|  |  | ||||||
| log4j.appender.file.File=${server.home}/logs/ncore-sample.log |  | ||||||
| log4j.appender.file.Append=true |  | ||||||
							
								
								
									
										62
									
								
								src/main/webapp/WEB-INF/logback.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										62
									
								
								src/main/webapp/WEB-INF/logback.xml
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,62 @@ | |||||||
|  | <?xml version="1.0" encoding="UTF-8"?> | ||||||
|  | <!-- | ||||||
|  |   ~ Copyright (C) 2022 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. | ||||||
|  |   --> | ||||||
|  |  | ||||||
|  | <configuration> | ||||||
|  | <!--   | ||||||
|  |   <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender"> | ||||||
|  |     <encoder> | ||||||
|  |       <pattern>%d{dd.MM.yy HH:mm:ss.SSS} [%t] %p %c{0} - %m%n</pattern> | ||||||
|  |     </encoder> | ||||||
|  |   </appender> | ||||||
|  | --> | ||||||
|  |  | ||||||
|  |   <appender name="FILE" class="ch.qos.logback.core.FileAppender"> | ||||||
|  |     <file>${catalina.home}/logs/ncore.log</file> | ||||||
|  |     <append>true</append> | ||||||
|  |     <immediateFlush>true</immediateFlush> | ||||||
|  |     <encoder> | ||||||
|  |       <charset>UTF-8</charset> | ||||||
|  |       <pattern>%d{dd.MM.yy HH:mm:ss.SSS} [%t] %p %c{0} - %m%n</pattern> | ||||||
|  |     </encoder> | ||||||
|  |   </appender> | ||||||
|  |  | ||||||
|  |   <root level="debug"> | ||||||
|  | <!--    <appender-ref ref="STDOUT" /> --> | ||||||
|  |     <appender-ref ref="FILE" /> | ||||||
|  |   </root> | ||||||
|  | </configuration> | ||||||
| @ -22,11 +22,12 @@ | |||||||
|   </context-param> |   </context-param> | ||||||
|   <servlet> |   <servlet> | ||||||
|     <servlet-name>ncore</servlet-name> |     <servlet-name>ncore</servlet-name> | ||||||
|     <servlet-class>biz.redsoft.ncore.server.NcoreApplicationServlet</servlet-class> |       <!-- <servlet-class>biz.redsoft.ncore_vaadin.server.NcoreApplicationServlet</servlet-class> --> | ||||||
|  |       <!-- <servlet-class>biz.redsoft.ncore_vaadinflow.server.NcoreApplicationServlet</servlet-class> --> | ||||||
|     <init-param> |     <init-param> | ||||||
|       <description>Vaadin application class to start</description> |       <description>Vaadin application class to start</description> | ||||||
|       <param-name>UI</param-name> |       <param-name>UI</param-name> | ||||||
|       <param-value>biz.redsoft.ncore.client.vaadin.WebApplication</param-value> |       <param-value>biz.redsoft.ncore_vaadin.client.vaadin.WebApplication</param-value> | ||||||
|     </init-param> |     </init-param> | ||||||
|     <init-param> |     <init-param> | ||||||
|       <description>Application widgetset</description> |       <description>Application widgetset</description> | ||||||
| @ -37,19 +38,20 @@ | |||||||
|  </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_vaadin.client.vaadin.VaadinSessionListener</listener-class> --> | ||||||
|  |     <!-- <listener-class>biz.redsoft.ncore_vaadinflow.client.vaadin.VaadinSessionListener</listener-class> --> | ||||||
|   </listener> |   </listener> | ||||||
| </web-app> | </web-app> | ||||||
|  | |||||||
| @ -6,17 +6,15 @@ 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 |  | ||||||
|  */ |  | ||||||
| public class SampleTests { | public class SampleTests { | ||||||
|   @Test |   @Test | ||||||
|   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
									
								
							| @ -1,25 +1,41 @@ | |||||||
| <?xml version="1.0" encoding="windows-1251"?> | <?xml version="1.0" encoding="UTF-8"?> | ||||||
| <Objects | <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"> | ||||||
|     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" | ||||||
|     <SysPatch |         SpNumber="1" SpRevision="1" SpStatus="2" SpSubsystem="SAMPLE" SpTimestamp="2025-05-27T19:56:20.177" SpUser="SYSDBA"> | ||||||
|         CreateDate="2015-03-01T21:15:50.513" |         <DetSysLogSysPatch> | ||||||
|         Description="<22><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> sample." |         <SysLog SlogAction="I" SlogAddress="127.0.0.1/54126" SlogSubsystem="NCORE" SlogTimestamp="2025-05-27T19:56:07.197" SlogTransaction="2808158" SlogUser="SYSDBA" | ||||||
|         Documentclassid="8001" |             SobjName="SYS_SUBSYSTEM"> | ||||||
|         DocDate="2015-03-01" |             <DetSysLogFieldsSysLog> | ||||||
|         DocNumber="SAMPLE-0000001" |             <SysLogFields SlfFieldName="CAPTION" SlfFieldString="SAMPLE" SlfIsNew="true"/> | ||||||
|         Metaobjectname="SYS_PATCH" |             <SysLogFields SlfFieldName="CODE" SlfFieldString="SAMPLE" SlfIsNew="true"/> | ||||||
|         SpControlNumber="644" |             <SysLogFields SlfFieldName="UPDATE_ORDER" SlfFieldString="10" SlfIsNew="true"/> | ||||||
|         SpControlProject="tracker" |         </DetSysLogFieldsSysLog> | ||||||
|         SpNumber="1" |     </SysLog> | ||||||
|         SpRevision="1" |     <SysLog SlogAction="I" SlogAddress="127.0.0.1/54126" SlogSubsystem="SAMPLE" SlogTimestamp="2025-05-27T19:56:07.197" SlogTransaction="2808158" SlogUser="SYSDBA" | ||||||
|         SpSqlAfter="" |         SobjName="SYS_LOOKUP"> | ||||||
|         SpSqlBefore="" |         <DetSysLogFieldsSysLog> | ||||||
|         SpStatus="2" |         <SysLogFields SlfFieldName="SDOM_NAME" SlfFieldString="D_SUBSYSTEM" SlfIsNew="true"/> | ||||||
|         SpSubsystem="SAMPLE" |         <SysLogFields SlfFieldName="SLU_CAPTION" SlfFieldString="SAMPLE" SlfIsNew="true"/> | ||||||
|         SpSyncSql="" |         <SysLogFields SlfFieldName="SLU_GROUP" SlfIsNew="true"/> | ||||||
|         SpTimestamp="2015-03-01T21:15:50.513" |         <SysLogFields SlfFieldName="SLU_KEY" SlfFieldString="SAMPLE" SlfIsNew="true"/> | ||||||
|         SpUser="<22><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>" |         <SysLogFields SlfFieldName="SLU_MEMO" SlfIsNew="true"/> | ||||||
|         TagList=""> |         <SysLogFields SlfFieldName="SLU_ORDER" SlfFieldString="10" SlfIsNew="true"/> | ||||||
|         <DetSysLogSysPatch/> |         <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> | </SysPatch> | ||||||
| </Objects> | </Objects> | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user