Files
chromebrew/packages/postgresql.rb
chromebrew-actions[bot] 40f766b34c updater-postgresql-18.0 — postgresql → 18.0 (#12927)
* Remove rebases from Build and Generate PR workflows & adjust versioning to handle libdb.

Signed-off-by: Satadru Pramanik <satadru@gmail.com>

* Add unbuilt postgresql to updater-postgresql-18.0

* updater-postgresql-18.0: Build Run on linux/arm/v7.

* updater-postgresql-18.0: Build Run on linux/amd64.

* updater-postgresql-18.0: Package File Update Run on linux/amd64 container.

---------

Signed-off-by: Satadru Pramanik <satadru@gmail.com>
Co-authored-by: Satadru Pramanik <satadru@gmail.com>
Co-authored-by: satmandu <satmandu@users.noreply.github.com>
Co-authored-by: chromebrew-actions[bot] <chromebrew-actions[bot]@users.noreply.github.com>
2025-09-25 17:43:57 +00:00

92 lines
2.9 KiB
Ruby

require 'buildsystems/meson'
class Postgresql < Meson
description 'PostgreSQL is a powerful, open source object-relational database system.'
homepage 'https://www.postgresql.org'
version "18.0-#{CREW_ICU_VER}"
license 'PostgreSQL and GPL-2'
compatibility 'aarch64 armv7l x86_64'
source_url "https://ftp.postgresql.org/pub/source/v#{version.split('-').first}/postgresql-#{version.split('-').first}.tar.bz2"
source_sha256 '0d5b903b1e5fe361bca7aa9507519933773eb34266b1357c4e7780fdee6d6078'
binary_compression 'tar.zst'
binary_sha256({
aarch64: 'db37f0edcd0957aa2ec6cee468392c530e6305da827ad89abeba85962aef77d7',
armv7l: 'db37f0edcd0957aa2ec6cee468392c530e6305da827ad89abeba85962aef77d7',
x86_64: '24618c801c76ed6c238c6d5a86ff142f81ace4665fcb6126493bd17c68413cdc'
})
depends_on 'brotli' => :build
depends_on 'curl' # R
depends_on 'docbook_xml45' => :build
depends_on 'expat' => :build
depends_on 'gcc_lib' # R
depends_on 'glibc' # R
depends_on 'icu4c' # R
depends_on 'krb5' # R
depends_on 'libcyrussasl' => :build
depends_on 'libxml2' # R
depends_on 'libxslt' # R
depends_on 'linux_pam' # R
depends_on 'llvm_dev' => :build
depends_on 'lz4' # R
depends_on 'openldap' # R
depends_on 'openssl' # R
depends_on 'perl' # R
depends_on 'python3' # R
depends_on 'readline' # R
depends_on 'tcl' # R
depends_on 'zlib' # R
depends_on 'zstd' # R
print_source_bashrc
PGDATA = "#{CREW_PREFIX}/share/pgsql/data".freeze
def self.patch
system "sed -i 's,PGDATA=\"/usr/local/pgsql/data\",PGDATA=\"#{PGDATA}\",' contrib/start-scripts/linux"
end
meson_install_extras do
# This conditional is needed for installation only.
unless Dir.exist? PGDATA
FileUtils.mkdir_p PGDATA
FileUtils.chmod 0o700, PGDATA
end
FileUtils.mkdir_p "#{CREW_DEST_PREFIX}/var/log/"
FileUtils.touch "#{CREW_DEST_PREFIX}/var/log/pgsql.log"
File.write 'postgresenv', <<~POSTGRESEOF
# PostgreSQL configuration
export PGDATA="#{PGDATA}"
# Start server on login
if [ -x #{CREW_PREFIX}/bin/pg_ctl ]; then
pg_ctl -l #{CREW_PREFIX}/var/log/pgsql.log start
fi
POSTGRESEOF
FileUtils.install 'postgresenv', "#{CREW_DEST_PREFIX}/etc/env.d/postgres", mode: 0o644
end
def self.postinstall
# This conditional is needed for installation only. If this package is updated in the future,
# there is no need to initialize the data directory and display messages again.
system "initdb -D #{PGDATA}" unless File.exist? "#{PGDATA}/PG_VERSION"
ExitMessage.add <<~EOM
To start postgres: pg_ctl -l logfile start
To stop postgres: pg_ctl stop
Create a database: createdb <dbname>
Connect to database: psql <dbname>
To configure, edit #{CREW_PREFIX}/etc/env.d/postgres
EOM
end
def self.postremove
puts 'WARNING: This will delete all databases!'.orange
Package.agree_to_remove(PGDATA)
end
end