~azzar1/unity/add-show-desktop-key

« back to all changes in this revision

Viewing changes to userdb/users.sql

  • Committer: Matt Giuca
  • Date: 2010-02-23 05:27:07 UTC
  • Revision ID: matt.giuca@gmail.com-20100223052707-3a76wo23r2z503t8
browser.js: Adjusted condition for enabling "Commit" action; now allowed if
    no files are selected AND current directory is versioned (as well as if
    all selected files are versioned). Committing with 0 files selected will
    commit the current directory.
ivle.fileservice_lib.action: Fixed to allow commit to contain 0 paths. This
    will commit the current directory instead.
This fixes Launchpad bug #526161.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
1
BEGIN;
2
 
 
3
 
CREATE OR REPLACE FUNCTION valid_url_name(name text) RETURNS boolean AS 
4
 
$$
5
 
    BEGIN
6
 
        RETURN name ~ E'^[a-z0-9][a-z0-9_\+\.\-]*$';
7
 
    END;
8
 
$$ LANGUAGE 'plpgsql';
9
 
 
10
 
CREATE OR REPLACE FUNCTION valid_login_name(name text) RETURNS boolean AS 
11
 
$$
12
 
    BEGIN
13
 
        RETURN name ~ E'^[a-z0-9][a-z0-9@_\+\.\-]*$';
14
 
    END;
15
 
$$ LANGUAGE 'plpgsql';
16
 
 
17
2
CREATE SEQUENCE login_unixid_seq MINVALUE 1000 MAXVALUE 29999 START WITH 5000;
18
3
 
19
4
CREATE TABLE login (
20
5
    loginid     SERIAL PRIMARY KEY NOT NULL,
21
 
    login       VARCHAR UNIQUE NOT NULL CHECK (valid_login_name(login)),
 
6
    login       VARCHAR UNIQUE NOT NULL,
22
7
    passhash    VARCHAR,
23
8
    state       VARCHAR NOT NULL CHECK (state in ('no_agreement', 'pending',
24
9
                                              'enabled', 'disabled'))
46
28
    subjectid       SERIAL PRIMARY KEY NOT NULL,
47
29
    subj_code       VARCHAR UNIQUE NOT NULL,
48
30
    subj_name       VARCHAR NOT NULL,
49
 
    subj_short_name VARCHAR UNIQUE NOT NULL CHECK (valid_url_name(subj_short_name))
 
31
    subj_short_name VARCHAR UNIQUE NOT NULL
50
32
);
51
33
 
52
34
CREATE TABLE semester (
53
35
    semesterid  SERIAL PRIMARY KEY NOT NULL,
54
 
    year        CHAR(4) NOT NULL CHECK (valid_url_name(year)),
55
 
    semester    CHAR(1) NOT NULL CHECK (valid_url_name(semester)),
 
36
    year        CHAR(4) NOT NULL,
 
37
    semester    CHAR(1) NOT NULL,
56
38
    state       TEXT NOT NULL CHECK (state IN ('disabled', 'past',
57
39
                                    'current', 'future')) DEFAULT 'current',
58
40
    UNIQUE (year, semester)
80
62
 
81
63
CREATE TABLE project (
82
64
    projectid   SERIAL PRIMARY KEY NOT NULL,
83
 
    short_name  TEXT NOT NULL CHECK (valid_url_name(short_name)),
 
65
    short_name  TEXT NOT NULL,
84
66
    name        TEXT NOT NULL,
85
67
    synopsis    TEXT,
86
68
    url         TEXT,
115
97
    FOR EACH ROW EXECUTE PROCEDURE check_project_namespacing_insertupdate();
116
98
 
117
99
CREATE TABLE project_group (
118
 
    groupnm     VARCHAR NOT NULL CHECK (valid_url_name(groupnm)),
 
100
    groupnm     VARCHAR NOT NULL,
119
101
    groupid     SERIAL PRIMARY KEY NOT NULL,
120
102
    projectsetid  INTEGER REFERENCES project_set (projectsetid) NOT NULL,
121
103
    nick        VARCHAR,
211
193
-- Worksheets
212
194
-- ----------
213
195
CREATE TABLE exercise (
214
 
    identifier  TEXT PRIMARY KEY CHECK (valid_url_name(identifier)),
 
196
    identifier  TEXT PRIMARY KEY,
215
197
    name        TEXT,
216
198
    description TEXT,
217
199
    partial     TEXT,
223
205
CREATE TABLE worksheet (
224
206
    worksheetid SERIAL PRIMARY KEY,
225
207
    offeringid  INT4 REFERENCES offering (offeringid) NOT NULL,
226
 
    identifier  TEXT NOT NULL CHECK (valid_url_name(identifier)),
 
208
    identifier  TEXT NOT NULL,
227
209
    name        TEXT NOT NULL,
228
210
    data        TEXT NOT NULL,
229
211
    assessable  BOOLEAN NOT NULL,