1   /*
2    * Licensed to the Apache Software Foundation (ASF) under one
3    * or more contributor license agreements.  See the NOTICE file
4    * distributed with this work for additional information
5    * regarding copyright ownership.  The ASF licenses this file
6    * to you under the Apache License, Version 2.0 (the
7    * "License"); you may not use this file except in compliance
8    * with the License.  You may obtain a copy of the License at
9    *
10   *     http://www.apache.org/licenses/LICENSE-2.0
11   *
12   * Unless required by applicable law or agreed to in writing,
13   * software distributed under the License is distributed on an
14   * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
15   * KIND, either express or implied.  See the License for the
16   * specific language governing permissions and limitations
17   * under the License.
18   */
19  package org.apache.shiro.aspectj;
20  
21  import org.apache.shiro.authz.annotation.RequiresAuthentication;
22  import org.apache.shiro.authz.annotation.RequiresGuest;
23  import org.apache.shiro.authz.annotation.RequiresPermissions;
24  import org.apache.shiro.authz.annotation.RequiresUser;
25  
26  import java.sql.Timestamp;
27  
28  /**
29   * Secured implementation of te dummy service that requires some permissions to execute.
30   *
31   */
32  public class SecuredDummyService implements DummyService {
33  
34      @RequiresAuthentication
35      @RequiresPermissions("dummy:admin")
36      public void change() {
37          retrieve();
38          log("change");
39          peek();
40      }
41  
42      public void anonymous() {
43          log("anonymous");
44      }
45  
46      @RequiresGuest
47      public void guest() {
48          log("guest");
49      }
50  
51      @RequiresUser
52      public void peek() {
53          log("peek");
54      }
55  
56      @RequiresPermissions("dummy:user")
57      public void retrieve() {
58          log("retrieve");
59      }
60  
61      public void log(String aMessage) {
62          if (aMessage != null) {
63              System.out.println(new Timestamp(System.currentTimeMillis()).toString() + " [" + Thread.currentThread() + "] * LOG * " + aMessage);
64          } else {
65              System.out.println("\n\n");
66          }
67      }
68  
69  }