Sophie

Sophie

distrib > Mandriva > 2010.1 > x86_64 > media > contrib-release > by-pkgid > aa0a0c745bf74bd0c70c4944117a40d3 > files > 100

gnugk-2.3.1-1mdv2010.1.x86_64.rpm

-- Tariff Group & Group Selector
--
-- VoIP Billing Platform for GnuGk
-- Copyright (c) 2004, Michal Zygmuntowicz
--
-- This work is published under the GNU Public License (GPL)
-- see file COPYING for details

-- This special table together with voiptariffsel makes possible
-- to arrange tariffs into groups and to apply groups to accounts.
-- As a result, during tariff matching, a group tariff 
-- has priority over a default tariff (without any group assigned)
CREATE SEQUENCE voiptariffgrp_id_seq CYCLE;
CREATE TABLE voiptariffgrp (
	id INT DEFAULT nextval('voiptariffgrp_id_seq'),
	-- greater the value, higher the priority during tariff matching
	priority INT NOT NULL DEFAULT 1,
	-- description (like 'Germany - 10% discount' or 'USA - Gold Tariff')
	description TEXT NOT NULL,
	
	CONSTRAINT voiptariffgrp_pkey PRIMARY KEY (id)
);

-- binding between an account and a tariff group
CREATE SEQUENCE voiptariffsel_id_seq CYCLE;
CREATE TABLE voiptariffsel (
	id INT DEFAULT nextval('voiptariffsel_id_seq'),
	-- tariff group identifier
	grpid INT NOT NULL,
	-- account the tariff group applies to
	accountid INT NOT NULL,
	
	CONSTRAINT voiptariffsel_pkey PRIMARY KEY (id),
	CONSTRAINT voiptariffsel_unique UNIQUE (grpid, accountid),
	CONSTRAINT voiptariffsel_group_exists FOREIGN KEY (grpid) REFERENCES voiptariffgrp(id) ON UPDATE CASCADE,
	CONSTRAINT voiptariffsel_account_exists FOREIGN KEY (accountid) REFERENCES voipaccount(id) ON UPDATE CASCADE
);