]> source.dussan.org Git - archiva.git/blob
459cb1bcc3b200cfbb1fbfcab1c24a6848406e05
[archiva.git] /
1 package org.apache.maven.archiva.database.constraints;
2
3 /*
4  * Licensed to the Apache Software Foundation (ASF) under one
5  * or more contributor license agreements.  See the NOTICE file
6  * distributed with this work for additional information
7  * regarding copyright ownership.  The ASF licenses this file
8  * to you under the Apache License, Version 2.0 (the
9  * "License"); you may not use this file except in compliance
10  * with the License.  You may obtain a copy of the License at
11  *
12  *  http://www.apache.org/licenses/LICENSE-2.0
13  *
14  * Unless required by applicable law or agreed to in writing,
15  * software distributed under the License is distributed on an
16  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
17  * KIND, either express or implied.  See the License for the
18  * specific language governing permissions and limitations
19  * under the License.
20  */
21
22 import org.apache.maven.archiva.database.Constraint;
23 import org.apache.maven.archiva.model.ArchivaArtifactModel;
24
25 import java.util.List;
26
27 /**
28  * UniqueGroupIdConstraint 
29  *
30  * @version $Id$
31  */
32 public class UniqueGroupIdConstraint
33     extends AbstractSimpleConstraint
34     implements Constraint
35 {
36     private StringBuffer sql = new StringBuffer();
37
38     public UniqueGroupIdConstraint()
39     {
40         /* this assumes search for no groupId prefix */
41         appendSelect( sql );
42         appendGroupBy( sql );
43     }
44
45     public UniqueGroupIdConstraint( List<String> selectedRepositories )
46     {
47         appendSelect( sql );
48         sql.append( " WHERE " );
49         SqlBuilder.appendWhereSelectedRepositories( sql, "repositoryId", selectedRepositories );
50         appendGroupBy( sql );
51     }
52
53     public UniqueGroupIdConstraint( List<String> selectedRepositories, String groupIdPrefix )
54     {
55         appendSelect( sql );
56         sql.append( " WHERE " );
57         SqlBuilder.appendWhereSelectedRepositories( sql, "repositoryId", selectedRepositories );
58         sql.append( " && " );
59         appendWhereGroupIdStartsWith( sql );
60         appendGroupBy( sql );
61
62         super.params = new Object[] { groupIdPrefix };
63     }
64
65     public UniqueGroupIdConstraint( String groupIdPrefix )
66     {
67         appendSelect( sql );
68         sql.append( " WHERE " );
69         appendWhereGroupIdStartsWith( sql );
70         appendGroupBy( sql );
71
72         super.params = new Object[] { groupIdPrefix };
73     }
74
75     @SuppressWarnings("unchecked")
76     public Class getResultClass()
77     {
78         return String.class;
79     }
80
81     public String getSelectSql()
82     {
83         return sql.toString();
84     }
85
86     private void appendGroupBy( StringBuffer buf )
87     {
88         buf.append( " GROUP BY groupId ORDER BY groupId ASCENDING" );
89     }
90
91     private void appendSelect( StringBuffer buf )
92     {
93         buf.append( "SELECT groupId FROM " ).append( ArchivaArtifactModel.class.getName() );
94     }
95
96     private void appendWhereGroupIdStartsWith( StringBuffer buf )
97     {
98         buf.append( " groupId.startsWith(groupIdPrefix) PARAMETERS String groupIdPrefix" );
99     }
100 }