Skip to main content

UniField python3 loader

Project description

ufload3

The Unifield Loader

Build Status

ufload3 is targeted at people who load dumps from live Unifield instances into non-production testing/staging/training instances. ufload3 will never leave a non-production database in a production configuration (it will stomp production passwords and disconnect from the live sync server).

ufload3 is 100% Python, and has been tested on Linux and Windows.

ufload3 can iterate over all the backups in a directory on ownCloud, and restore the latest backup for each instance. You can limit the list of instances to be restored.

ufload3 can make coffee for you in the morning, and then do your dishes.

Installing on Windows

  1. Install Python 3.10 from here: https://www.python.org/downloads/windows/
  2. Add this directory to your PATH, separated from previous ones by a semi-colon:
  • ;C:\Python27;C:\Python27\Scripts or with cmd line in windows: SETX /M PATH "%PATH%;C:\Python3;C:\Python3\Scripts"
  1. In a new CMD.EXE window, type: pip install --upgrade ufload3
  2. Run ufload3 -h to get help.
  3. Use Notepad to create a config file. Put the file in the same place CMD.EXE starts from, for example d:\Users\jae. The file should be named ufload3.txt. Be careful: notepad.exe will create a file called ufload3.txt.txt by default. To avoid this, use "Save as..." and do not include .txt. Put the following into it:
[owncloud]
user=username
pw=password for OneDrive backup
oc=your OC:OCA/OCB/OCG/OCP

[postgres]
db_user=openpg
db_pw=yourdatabasepassword

[restore]
#adminuser=admin
#adminpw=youradminpassword
#userspw=youruserpassword
workingdir=D:\

[logs]
local=D:\logs
  1. Use "dir" to confirm that the file is where you expect it to be, and is named "ufload3.txt" and not "ufload3.txt.txt".

For each line, put the right thing. If you do not want to put your password in the file, you can add the -pw flag to any command, after ufload3.exe.

Installing on Linux

sudo pip install --upgrade ufload3

The config file is in $HOME/.ufload3

Upgrading

Use the same command as you used to install it: pip install --upgrade ufload3

Example Commands

To see a list of all backup files for an instance: ufload3 ls -i OCG_HQ

For all instances, remove the -i flag.

To load all of the instances from OneDrive: ufload3 restore

To load the OCG_HQ instance and all the OCG_NE1 instances from OneDrive: ufload3 restore -i OCG_HQ -i OCG_NE1

To load the OCG_HQ and OCG_NE1 instances from OneDrive and load a sync server: ufload3 restore -i OCG_HQ -i OCG_NE1 -load-sync-server

Scheduling ufload3 in Windows

You can use the Windows Task Scheduler to run ufload3 in order to update a sandbox environment every night.

Use the remote option in the [logs] section to arrange for remote logging.

Use a command like this to schedule it once a day: schtasks /create /F /TN Ufload /SC DAILY /st 20:00 /tr "cmd.exe /C start /min cmd.exe /C C:\python27\Scripts\ufload3 restore -load-sync-server"

Or this to make it run every hour: schtasks /create /F /TN Ufload /SC DAILY /RI 60 /st 00:00 /du 24:00 /tr "cmd.exe /C start /min cmd.exe /C C:\python27\Scripts\ufload3 restore -load-sync-server"

Integrating other tools into ufload3

Ufload's restore command has a -notify flag which will call a program each time a database is sucessfully loaded. The program receives the name of the newly loaded database as it's first argument.

For instance, the following script sends e-mail when a backup file is older than expected:

#!/bin/sh

db=$1

# Convert OCG_NE1_COO_20161210_2102 into 20161210
d=`echo $db | perl -F_ -lane 'print $F[-2]'`
limit=`date --date='5 days ago' +%Y%m%d`

if [ "$d" -lt "$limit" ]; then
   echo "Database $db is too old." | mail user@example.org
fi

If it was loaded in /bin/notify-old-db, then ufload3 restore -notify /bin/notify-old-db will run the script.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ufload3-1.9.tar.gz (30.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

ufload3-1.9-py3-none-any.whl (30.3 kB view details)

Uploaded Python 3

File details

Details for the file ufload3-1.9.tar.gz.

File metadata

  • Download URL: ufload3-1.9.tar.gz
  • Upload date:
  • Size: 30.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.10.17

File hashes

Hashes for ufload3-1.9.tar.gz
Algorithm Hash digest
SHA256 37dc817f735cf66df61af3e298b98ae903f3c0eeca3030b614623d5fe34c8733
MD5 bd9c42fe7283743b5b5e3452420f662e
BLAKE2b-256 8336391638961367fe2a1c50ba7ec0ce2442208e15b6e2eba0aef42e87480e1a

See more details on using hashes here.

File details

Details for the file ufload3-1.9-py3-none-any.whl.

File metadata

  • Download URL: ufload3-1.9-py3-none-any.whl
  • Upload date:
  • Size: 30.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.10.17

File hashes

Hashes for ufload3-1.9-py3-none-any.whl
Algorithm Hash digest
SHA256 d0aa8e1f53129e91661d23c46045463d7a6a68f757ecfd7ec386b307bf8423d8
MD5 f2cb797612f30b4328509209a2bbead4
BLAKE2b-256 e08af1eafd120fd2d956abd8f5391ef1ae12cca109bf56448517025037a9aa7e

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page