Apache OFBiz is an open source product for the automation of enterprise processes. It includes framework components and business applications for ERP, CRM, E-Business/E-Commerce, Supply Chain Management and Manufacturing Resource Planning. OFBiz provides a foundation and starting point for reliable, secure and scalable enterprise solutions.
////
Licensed to the Apache Software Foundation (ASF) under one
or more contributor license agreements. See the NOTICE file
distributed with this work for additional information
regarding copyright ownership. The ASF licenses this file
to you under the Apache License, Version 2.0 (the
“License”); you may not use this file except in compliance
with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing,
software distributed under the License is distributed on an
“AS IS” BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
KIND, either express or implied. See the License for the
specific language governing permissions and limitations
under the License.
////
[[apache-ofbiz]]
= Apache OFBiz®
The Apache OFBiz Project
image:https://img.shields.io/badge/License-Apache 2.0-blue.svg[link=http://www.apache.org/licenses/LICENSE-2.0]
image:https://img.shields.io/badge/Version-trunk-red.svg[link=https://github.com/apache/ofbiz-framework]
image:https://github.com/apache/ofbiz-framework/actions/workflows/gradle.yaml/badge.svg?branch=trunk[link=https://github.com/apache/ofbiz-framework/actions/workflows/gradle.yaml]
// For the CodeQL badge to not get stuck on failing, you need to delete the last failing CodeQL workflow (AKA action)
image:https://github.com/apache/ofbiz-framework/actions/workflows/codeql-analysis.yml/badge.svg[link=https://github.com/apache/ofbiz-framework/actions/workflows/codeql-analysis.yml]
// For the BuildBot badge to not get stuck on failure, ALL builds of all branches handled by https://svn.apache.org/repos/infra/infrastructure/buildbot2/projects/ofbiz.py need to pass
image:https://ci2.apache.org/badges/ofbizTrunkFrameworkPlugins.svg[link=https://ci2.apache.org/#/builders?tags=%2BofbizTrunkFrameworkPlugins]
image:https://qpkb254zxeu.montastic.io/badge[link=https://qpkb254zxeu.montastic.io]
image:https://github.com/apache/ofbiz-framework/actions/workflows/scorecard.yml/badge.svg[https://github.com/apache/ofbiz-framework/actions/workflows/scorecard.yml]
image:https://api.securityscorecards.dev/projects/github.com/apache/ofbiz-framework/badge[link=https://securityscorecards.dev/viewer/?uri=github.com/apache/ofbiz-framework]
image:https://www.bestpractices.dev/projects/8708/badge[link=https://www.bestpractices.dev/projects/8708]
If you are reading this file in AsciiDoc format you may want to see it at
https://nightlies.apache.org/ofbiz/trunk/readme/html5/README.html[HTML]
or https://nightlies.apache.org/ofbiz/trunk/readme/pdf/README.pdf[PDF] format
Welcome to Apache OFBiz! A powerful top level Apache software project. OFBiz
is an Enterprise Resource Planning (ERP) System written in Java and houses a
large set of libraries, entities, services and features to run all aspects of
your business.
For more details about OFBiz please visit the OFBiz Documentation page:
http://ofbiz.apache.org/documentation.html[OFBiz documentation]
http://www.apache.org/licenses/LICENSE-2.0[OFBiz License]
[[system-requirements]]
== System requirements
The only requirements to run OFBiz is
[[quick-start]]
// tag::quickstart[]
== Quick start
To quickly install and fire-up OFBiz, please follow the below instructions from
the command line at the OFBiz top level directory (folder).
[[download-the-gradle-wrapper]]
=== Download the Gradle wrapper:
init-gradle-wrapper
“Powershell is not recognized as an internal or external command, operable program or batch file”
follow the advice there: https://s.apache.org/vdcv8. If you want more details see: https://s.apache.org/urnju
Unix-like OS: ./gradle/init-gradle-wrapper.sh
[[prepare-ofbiz]]
=== Prepare OFBiz:
==== Clean system and load the complete OFBiz data
Note: Depending on your Internet connection speed it might take a long time
for this step to complete if you are using OFBiz for the first time as it needs
to download all dependencies. So please be patient!
MS Windows: gradlew cleanAll loadAll
Unix-like OS: ./gradlew cleanAll loadAll
[[start-ofbiz]]
=== Start OFBiz:
MS Windows: gradlew ofbiz
Unix-like OS: ./gradlew ofbiz
Note: Ignore the % progress indicator because this task does not end as long
as OFBiz is running.
[[Docker]]
== Docker
If you want to set and use Docker, link:https://nightlies.apache.org/ofbiz/trunk/readme/html5/DOCKER.html[here is the documentation]
[[visit-ofbiz-through-your-browser]]
=== Visit OFBiz through your browser:
https://localhost:8443/ordermgr[Order Back Office interface]
https://localhost:8443/accounting[Accounting Back Office interface]
https://localhost:8443/webtools[Administrator interface]
You can log in with the user admin and password ofbiz.
// end::quickstart[]
[NOTE]
In case of problems visit our link:#further-reading[Further reading section].
[[security]]
== Security
If you find a pre-auth security issue, please report it to: security @ ofbiz.apache.org.
Once proper mitigations to the security issues are complete the OFBiz team will
disclose this information to the public mailing list.
If you find a post-auth security issue, please https://s.apache.org/dsj2p[create a bug in our issue tracker (Jira)] .
If you want to use AJP on a non localhost OFBiz instance, you need to set the value of allowedRequestAttributesPattern
in framework/catalina/ofbiz-component.xml
You can find more information about security in OFBiz at
https://cwiki.apache.org/confluence/display/OFBIZ/Keeping+OFBiz+secure[Keeping OFBiz secure]
In production never use the credentials contained in demo data. Not only the admin credentials, but all of them.
[[build-system-syntax]]
== Build system syntax
All build tasks are executed using the Gradle build system which is embedded
in OFBiz. To execute build tasks go to OFBiz top-level directory (folder) and
execute tasks from there.
[[operating-system-syntax]]
=== Operating System Syntax
The syntax for tasks differ slightly between windows and Unix-like systems
gradlew <tasks-in-here>
./gradlew <tasks-in-here>
For the rest of this document, we will use the windows syntax, if you are on a
Unix-like system, you need to add the ./
to gradlew
[[types-of-tasks-in-gradle]]
=== Types of tasks in Gradle
There are two types of tasks designed for OFBiz in Gradle:
Tips:
gradlew "ofbiz --help"
gradlew loadAdminUserLogin -PuserLoginId=myadmin
=gradlew lAUL -PuserLoginId=myadmin
gradlew build -x test
does not run the tests within the build.[[example-standard-tasks]]
==== Example standard tasks
gradlew build
gradlew cleanAll loadAll testIntegration
[[example-ofbiz-server-tasks]]
==== Example OFBiz server tasks
gradlew "ofbiz --help"
gradlew "ofbiz --test" --debug-jvm
gradlew "ofbizBackground --start --portoffset 10000"
gradlew "ofbiz --shutdown --portoffset 10000"
gradlew ofbiz
(default is --start)
[[example-mixed-tasks-standard-and-ofbiz-server]]
==== Example mixed tasks (standard and OFBiz server)
gradlew cleanAll loadAll "ofbiz --start --portoffset 10000"
[[quick-reference]]
== Quick reference
You can use the below common list of tasks as a quick reference for controlling
the system. This document uses the windows task syntax, if you are on a
Unix-like system, you need to add the ./
to gradlew i.e. ./gradlew
[[help-tasks]]
=== Help tasks
[[list-ofbiz-server-commands]]
==== List OFBiz server commands
List all available commands to control the OFBiz server
gradlew "ofbiz --help"
[[list-build-tasks]]
==== List build tasks
List all available tasks from the build system
gradlew tasks
[[list-build-projects]]
==== List build projects
List all available projects in the build system
gradlew projects
[[gradle-build-system-help]]
==== Gradle build system help
Show usage and options for the Gradle build system
gradlew --help
[[server-command-tasks]]
=== Server command tasks
[[start-ofbiz-1]]
==== Start OFBiz
gradlew "ofbiz --start"
start is the default server task so this also works:
gradlew ofbiz
[[shutdown-ofbiz]]
==== Shutdown OFBiz
gradlew "ofbiz --shutdown"
[[get-ofbiz-status]]
==== Get OFBiz status
gradlew "ofbiz --status"
[[force-ofbiz-shutdown]]
==== Force OFBiz shutdown
Terminate all running OFBiz server instances by calling the appropriate
operating system kill command. Use this command to force OFBiz termination if
the --shutdown command does not work. Usually this is needed when in the middle
of data loading or testing in OFBiz.
Warning: Be careful in using this command as force termination might lead to inconsistent state / data
gradlew terminateOfbiz
[[start-ofbiz-in-remote-debug-mode]]
==== Start OFBiz in remote debug mode
Starts OFBiz in remote debug mode and waits for debugger or IDEs to connect on
port 5005
gradlew ofbiz --debug-jvm
[[start-ofbiz-on-a-different-port]]
==== Start OFBiz on a different port
Start OFBiz of the network port offsetted by the range provided in the argument
to --portoffset
gradlew "ofbiz --start --portoffset 10000"
[[start-ofbiz-in-the-background]]
==== Start OFBiz in the background
Start OFBiz in the background by forking it to a new process and redirecting the
output to runtime/logs/console.log
gradlew "ofbizBackground --start"
OR
gradlew ofbizBackground
You can also offset the port, for example:
gradlew "ofbizBackground --start --portoffset 10000"
[[passing-jvm-runtime-options-to-ofbiz]]
==== Passing JVM runtime options to OFBiz
You can pass JVM runtime options by specifying the project property -PjvmArgs
.
gradlew ofbiz -PjvmArgs="-Xms1024M -Xmx2048M" -Dsome.parameter=hello
If you do not specify jvmArgs
, a default of -Xms128M -Xmx1024M
is set.
[[data-loading-tasks]]
=== Data loading tasks
OFBiz contains the following data reader types:
Available options for the --load-data server command are the following:
[[load-specific-ofbiz-data]]
==== Load specific OFBiz data
you can choose which data readers to pass in the following syntax:
gradlew "ofbiz --load-data readers=<readers-here-comma-separated>"
Example:
gradlew "ofbiz --load-data readers=seed,seed-initial,ext,ext-demo"
Beware that copying this command in Microsoft Word will automatically transform
the double dash in en dashes (Unicode 0x2013: –) Other cases not related to Word
were also reported.So when this command does not work check that you are using
dash!
[[load-all-ofbiz-data]]
==== Load all OFBiz data
Loads all data sets; meant for initial loading of generic OFBiz data. Can be
applied for development, testing, demonstration, etc. purposes. Be aware that
executing this task can result in your data being overwritten in your database
of choice.
gradlew loadAll
OR gradlew "ofbiz --load-data"
[CAUTION]
Use with caution in production environments.
[[load-seed-data]]
==== Load seed data
Load ONLY the seed data (not seed-initial, demo, ext* or anything else); meant
for use after an update of the code to reload the seed data as it is generally
maintained along with the code and needs to be in sync for operation
gradlew "ofbiz --load-data readers=seed"
[[load-ext-data]]
==== load ext data
Load seed, seed-initial and ext data; meant for manual/generic testing,
development, or going into production with a derived system based on stock OFBiz
where the ext data basically replaces the demo data
gradlew "ofbiz --load-data readers=seed,seed-initial,ext"
[[load-ext-test-data]]
==== load ext test data
Load seed, seed-initial, ext and ext-test data; meant for automated testing with
a derived system based on stock OFBiz
gradlew "ofbiz --load-data readers=seed,seed-initial,ext,ext-test"
[[load-data-from-an-entity-file]]
==== load data from an entity file
Load data from an XML file holding entity data.
gradlew "ofbiz --load-data file=foo/bar/FileNameHere.xml"
[[create-a-new-tenant]]
==== create a new tenant
Create a new tenant in your environment, create the delegator, load initial data
with admin-user and password (needs multitenant=Y in general.properties). The
following project parameters are passed:
gradlew createTenant -PtenantId=mytenant
gradlew createTenant -PtenantId=mytenant -PtenantName="My Name" -PdomainName=com.example -PtenantReaders=seed,seed-initial,ext -PdbPlatform=M -PdbIp=127.0.0.1 -PdbUser=mydbuser -PdbPassword=mydbpass
If run successfully, the system creates a new tenant having:
[[load-data-for-a-specific-tenant]]
==== load data for a specific tenant
Load data for one specific tenant in a multitenant environment. Note that you
must set multitenant=Y in general.properties and the following project
parameters are passed:
gradlew loadTenant -PtenantId=mytenant
gradlew loadTenant -PtenantId=mytenant -PtenantReaders=seed,seed-initial,demo -PtenantComponent=base
[[testing-tasks]]
=== Testing tasks
// tag::testingtasks[]
[[execute-all-unit-tests]]
==== Execute all unit tests (no need access to the DB)
gradlew test
[[execute-all-integration-tests]]
==== Execute all integration tests (need access to the DB)
gradlew testIntegration
OR
gradlew 'ofbiz --test'
[[execute-integration-tests-with-a-different-log-level]]
==== Execute integration tests with a different log level
It is possible to start integration tests with a log level different from the
default one. The log levels allowed are listed below from most verbose to least
verbose:
gradlew "ofbiz --test loglevel=fatal"
[[execute-an-integration-test-case]]
==== Execute an integration test case
Run a test case, in this example the component is “entity” and the case name is
“entity-tests”
gradlew "ofbiz --test component=entity --test suitename=entitytests --test case=entity-query-tests"
[[execute-an-integration-test-case-in-debug-mode-with-verbose-log]]
==== Execute an integration test case in debug mode with verbose log
Listens on port 5005
gradlew "ofbiz --test component=entity --test loglevel=verbose" --debug-jvm
[[execute-an-integration-test-suite]]
==== Execute an integration test suite
gradlew "ofbiz --test component=entity --test suitename=entitytests"
[[execute-an-integration-test-suite-in-debug-mode]]
==== Execute an integration test suite in debug mode
Listens on port 5005
gradlew "ofbiz --test component=entity --test suitename=entitytests" --debug-jvm
[[execute-all-component-tests]]
==== Execute all component tests
gradlew "ofbiz --test component=entity"
[[execute-all-component-tests-in-debug-mode]]
==== Execute all component tests in debug mode
Listens on port 5005
gradlew "ofbiz --test component=entity" --debug-jvm
// end::testingtasks[]
[[miscellaneous-tasks]]
=== Miscellaneous tasks
[[run-all-tests-on-a-clean-system]]
==== Run all tests on a clean system
gradlew cleanAll loadAll testIntegration
[[clean-all-generated-artifacts]]
==== Clean all generated artifacts
gradlew cleanAll
[[refresh-the-generated-artifacts]]
==== Refresh the generated artifacts
gradlew clean build
[[create-an-admin-user-account]]
==== Create an admin user account
Create an admin user with login name MyUserName and default password with value
“ofbiz”. Upon first login OFBiz will request changing the default password
gradlew loadAdminUserLogin -PuserLoginId=MyUserName
[[compile-java-without-using-xlint-output]]
==== Compile Java without using Xlint output
By default Xlint prints output of all warnings detected by the compiler, if you
want to silence them
gradlew -PXlint:none build
[[run-owasp-tool-to-identify-dependency-vulnerabilities-cves]]
==== Run OWASP tool to identify dependency vulnerabilities (CVEs)
The below command activates a gradle plugin (OWASP) and Identifies and reports
known vulnerabilities (CVEs) in OFBiz library dependencies. The task takes time
to complete, and once done, a report will be generated in
$OFBIZ_HOME/build/reports/dependency-check-report.html
gradlew -PenableOwasp dependencyCheckAnalyze
[[setup-eclipse-project-for-ofbiz]]
==== Setup eclipse project for OFBiz
Setting up OFBiz on eclipse is done by simply running the below command and then
importing the project to eclipse. This command will generate the necessary
.classpath and .project files for eclipse and it will also make the source
code for external libraries available in eclipse (i.e. you can view source
through Ctrl + Click)
The first time you run this command it will take a long time to execute because
it will download source packages available for project dependencies.
gradlew eclipse
[[package-and-distribute-ofbiz]]
==== Package and distribute OFBiz
In order to deploy OFBiz on a target system and in particular in a production
environment without requiring the target system to download Gradle and OFBiz
dependencies from the internet, it is possible to generate an archive bundling
OFBiz with all the Jars it depends on as a tar
archive
gradlew distTar
or as a zip
archive.
gradlew distZip
Those archives are available in the build/distributions
directory. To run
OFBiz from those archive you must first unarchive them with tar xf
or unzip
and then from that directory you can run either bin/ofbiz
shell script or
bin/ofbiz.bat
batch script with the appropriate ofbiz options.
[[ofbiz-plugin-system]]
== OFBiz plugin system
OFBiz provides an extension mechanism through plugins. Plugins are standard
OFBiz components that reside in the plugins directory. Plugins can be added
manually or fetched from a maven repository. The standard tasks for managing
plugins are listed below.
Note: OFBiz plugin versions follow http://semver.org/[Semantic Versioning
2.0.0]
[[pull-download-and-install-a-plugin-automatically]]
=== Pull (download and install) a plugin automatically
Download a plugin with all its dependencies (plugins) and install them
one-by-one starting with the dependencies and ending with the plugin itself.
gradlew pullPlugin -PdependencyId="org.apache.ofbiz.plugin:myplugin:0.1.0"
If the plugin resides in a custom maven repository (not jcenter or localhost)
then you can use specify the repository using below command:
gradlew pullPlugin -PrepoUrl="http://www.example.com/custom-maven" -PdependencyId="org.apache.ofbiz.plugin:myplugin:0.1.0"
If you need username and password to access the custom repository:
gradlew pullPlugin -PrepoUrl="http://www.example.com/custom-maven" -PrepoUser=myuser -PrepoPassword=mypassword -PdependencyId="org.apache.ofbiz.plugin:myplugin:0.1.0"
[[pull-an-official-plugin-from-source-control]]
=== Pull an official plugin from source control
Download an official plugin from source control and place it in the plugins directory.
It’s able to handle branches switches
MS Windows: pullPluginSource example
+
Unix-like OS: ./pullPluginSource.sh example
[[pull-all-official-plugins-from-source-control]]
=== Pull all official plugins from source control
Download all officially supported plugins from source control and place them in /plugins.
It’s able to handle branches switches
MS Windows: pullAllPluginsSource
+
Unix-like OS: ./pullAllPluginsSource.sh
[[install-a-plugin]]
=== Install a plugin
If you have a plugin called mycustomplugin and want to install it in OFBiz
follow the below instructions:
gradlew installPlugin -PpluginId=myplugin
The above commands executes the task “install” in the plugin’s build.gradle file
if it exists
[[uninstall-a-plugin]]
=== Uninstall a plugin
If you have an existing plugin called mycustomplugin and you wish to uninstall
run the below command
gradlew uninstallPlugin -PpluginId=myplugin
The above command executes the task “uninstall” in the plugin’s build.gradle
file if it exists
[[remove-a-plugin]]
=== Remove a plugin
Calls uninstallPlugin on an existing plugin and then delete it from the
file-system
gradlew removePlugin -PpluginId=myplugin
[[create-a-new-plugin]]
=== Create a new plugin
Create a new plugin. The following project parameters are passed:
gradlew createPlugin -PpluginId=myplugin
gradlew createPlugin -PpluginId=myplugin -PpluginResourceName=MyPlugin -PwebappName=mypluginweb -PbasePermission=MYSECURITY
The above command creates a new plugin in /plugins/myplugin
[[push-a-plugin-to-a-repository]]
=== Push a plugin to a repository
This task publishes an OFBiz plugin into a maven package and then uploads it to
a maven repository. Currently, pushing is limited to localhost maven repository
(work in progress). To push a plugin the following parameters are passed:
gradlew pushPlugin -PpluginId=myplugin
gradlew pushPlugin -PpluginId=mycompany -PpluginGroup=com.mycompany.ofbiz.plugin -PpluginVersion=1.2.3 -PpluginDescription="Introduce special functionality X"
[[miscellaneous-documentation]]
== Miscellaneous Documentation
[[further-reading]]
=== Further reading
[[repository-and-directory-structure]]
=== Repository and directory structure
OFBiz is split into two repositories:
Furthermore, the hot-deploy directory is removed as the plugins directory works
as a replacement for both “special-purpose” and “hot-deploy”.
If you need to load the components in the plugins directory in a specific order
place a component-load.xml file in the plugins directory listing the order.
To check out a plugin from source control use the Windows or Unix-like pullPluginSource script.
To check out all plugins from source control use the
pullAllPluginsSource script. Beware this deletes a previously existing plugins
directory.
[[running-gradle-tasks-without-an-internet-connection]]
=== Running gradle tasks without an internet connection
OFBiz must run with an internet connection the first time it is prepared on
the system because it needs to download all the required dependencies.
After preparing OFBiz the first time correctly, it is possible to run OFBiz
without an internet connection by using the --offline
command line switch
which tells Gradle to fetch its dependencies from the cache.
If any dependencies are missing from the cache and you pass --offline
switch
then the build execution will fail.
[[setup-an-external-database-like-mysql-postgresql-etc]]
=== Setup an external database like MySQL, PostgreSQL, etc
To setup an external database instead of the default embedded Apache Derby, you
will need to follow the following instructions:
runtime 'mysql:mysql-connector-java:8.0.30'
OR
[[setup-gradle-tab-completion-on-unix-like-systems]]
=== Setup gradle tab-completion on Unix-like systems:
To get tab completion (auto complete gradle commands by pressing tab) you can
download the script from the below link and place it in the appropriate location
for your system.
https://edub.me/gradle-completion-bash[Gradle tab completion]
For example, on debian based systems, you can use the following command:
sudo curl -L -s https://edub.me/gradle-completion-bash -o /etc/bash_completion.d/gradle-tab-completion.bash
[[crypto-notice]]
== Crypto notice
This distribution includes cryptographic software. The country in which you
currently reside may have restrictions on the import, possession, use, and/or
re-export to another country, of encryption software. BEFORE using any
encryption software, please check your country’s laws, regulations and policies
concerning the import, possession, or use, and re-export of encryption software,
to see if this is permitted. See http://www.wassenaar.org/ for more information.
The U.S. Government Department of Commerce, Bureau of Industry and Security
(BIS), has classified this software as Export Commodity Control Number (ECCN)
5D002.C.1, which includes information security software using or performing
cryptographic functions with asymmetric algorithms. The form and manner of this
Apache Software Foundation distribution makes it eligible for export under the
License Exception ENC Technology Software Unrestricted (TSU) exception (see the
BIS Export Administration Regulations, Section 740.13) for both object code and
source code.
The following provides more details on the included cryptographic software: