./: build.sbt ./javascript: user.js ./pages: index.html layout.html login.html ./sql: 1.sql ./locale: messages_en.properties ./src/main/scala/com/igumnov/scala-2.11/example: ExampleUser.scala SiteServer.scala
name := "example-scala" version := "1.0" scalaVersion := "2.11.7" libraryDependencies += "com.igumnov.scala" % "scala-common_2.11" % "0.5" // libraryDependencies += "com.h2database" % "h2" % "1.4.187" // // Bootstrap, AnglularJS webjars libraryDependencies += "org.webjars" % "angular-ui-bootstrap" % "0.12.0" libraryDependencies += "org.webjars" % "angularjs" % "1.3.8" libraryDependencies += "org.webjars" % "bootstrap" % "3.3.1"
package com.igumnov.scala.example import java.util.Calendar import com.igumnov.scala._ import com.igumnov.scala.webserver.User object SiteServer { def main(args: Array[String]) { // ( 3 ) ORM.connectionPool("org.h2.Driver", "jdbc:h2:mem:test", "SA", "", 1, 3) // ORM.applyDDL("sql") // WebServer.setPoolSize(5,10) // - WebServer.init("localhost", 8989) // WebServer.loginService((name) => { val user = ORM.findOne[ExampleUser](name) if (user.isDefined) { Option(new User(user.get.userName, user.get.userPassword, Array[String]("user_role"))) } else { Option(null) } }) // URL- WebServer.securityPages("/login", "/login?error=1", "/logout") // user_role WebServer.addRestrictRule("/*", Array("user_role")) // WebServer.addAllowRule("/static/*") // classpath webjars WebServer.addClassPathHandler("/static", "META-INF/resources/webjars") // Java Script- WebServer.addAllowRule("/js/*") // Java Script WebServer.addStaticContentHandler("/js", "javascript") // ( ) // - WebServer.locale(Map("en" -> "locale/messages_en.properties"), (rq,rs)=>{ "en" }) // WebServer.templates("pages",0) // "/", , index.html WebServer.addController("/", (rq, rs,model) => { model += "time" -> Calendar.getInstance.getTime "index" }) // "/login", , login.html WebServer.addController("/login", (rq, rs,model) => { "login" }) // REST- "/rest/user" POST/PUT JSON- ExampleUser WebServer.addRestController[ExampleUser]("/rest/user", (rq, rs, obj) => { rq.getMethod match { case "GET" => { // GET ORM.findAll[ExampleUser]() // } case "POST" => { // POST val user = obj.get user.userPassword = WebServer.crypthPassword(user.userName, user.userPassword) ORM.insert(obj.get) // } case "DELETE" => { // DELETE val user = ORM.findOne[ExampleUser](rq.getParameter("userName")) // demo if(user.get.userName == "demo") throw new Exception("You cant delete demo user") ORM.delete(user.get) user.get } } }) // JSON Error WebServer.addRestErrorHandler((rq, rs, e) => { object Error{ var message:String =_ } Error.message = e.getMessage Error }) val users = ORM.findAll[ExampleUser] // if(users.size==0) { // val user = new ExampleUser user.userName="demo" user.userPassword=WebServer.crypthPassword(user.userName, "demo") ORM.insert(user) // demo/demo } // Exception, - :) WebServer.start } }
// JSON package com.igumnov.scala.example import com.igumnov.scala.orm.Id class ExampleUser { @Id(autoIncremental = false) var userName: String = _ var userPassword: String = _ }
# ORM ExampleUser.class CREATE TABLE ExampleUser (userName VARCHAR(255) PRIMARY KEY, userPassword VARCHAR(255))
<!DOCTYPE html SYSTEM "http://www.thymeleaf.org/dtd/xhtml1-strict-thymeleaf-spring4-4.dtd"> <!-- layout layout.html --> <html xmlns:th="http://www.thymeleaf.org" xmlns:layout="http://www.ultraq.net.nz/thymeleaf/layout" layout:decorator="layout"> <body> <!-- layout.html --> <div layout:fragment="content"> <form name="form" action="/j_security_check" method="POST"> <div class="modal-header"> <h3 class="modal-title" th:text="#{login.title}"></h3> <!-- --> </div> <div class="modal-body"> <div class="form-group"> <input type="text" name="j_username" class="form-control" value="" placeholder="Login"/> </div> <div class="form-group"> <input type="password" name="j_password" class="form-control" placeholder="Password"/> </div> <div class="form-group"> <button type="submit" id="login" class="btn btn-primary">OK</button> </div> </div> </form> </div> </body> </html>
<!DOCTYPE html SYSTEM "http://www.thymeleaf.org/dtd/xhtml1-strict-thymeleaf-spring4-4.dtd"> <!-- layout layout.html --> <html xmlns:th="http://www.thymeleaf.org" xmlns:layout="http://www.ultraq.net.nz/thymeleaf/layout" layout:decorator="layout"> <body> <!-- layout.html --> <div layout:fragment="content"> <!-- AngularJS--> <script src="/js/user.js"></script> <h1 th:text="${time}"></h1> // <!-- UserCtrl --> <div ng-controller="UserCtrl"> <table class="table"> <thead> <tr> <th>Name</th> <th>Password</th> <th></th> </tr> </thead> <tbody> <!-- --> <tr ng-repeat="user in users"> <td>{{user.userName}}</td> <td>{{user.userPassword}}</td> <!-- --> <td><a href="#"><span class="glyphicon glyphicon-remove" tooltip="Delete" ng-click="deleteUser(user)"/></a></td> </tr> </tbody> </table> <div ng-model="user"> <!-- --> <div class="form-group"> <input type="text" class="form-control" ng-model="user.userName" placeholder="Login"/> </div> <div class="form-group"> <input type="password" class="form-control" ng-model="user.userPassword" placeholder="Password"/> </div> <div class="form-group"> <!-- --> <button class="btn btn-primary" ng-click="addUser(user)">Add</button> </div> </div> </div> </div> </body> </html>
<!DOCTYPE html SYSTEM "http://www.thymeleaf.org/dtd/xhtml1-strict-thymeleaf-spring4-4.dtd"> <!-- AngularJS --> <html ng-app="com.igumnov.common.example"> <head> <title>Title</title> <link rel="stylesheet" href="/static/bootstrap/3.3.1/css/bootstrap.min.css" /> <meta charset="utf-8" /> <meta http-equiv="X-UA-Compatible" content="IE=edge" /> <meta name="viewport" content="width=device-width, initial-scale=1" /> </head> <body> <script src="/static/angularjs/1.3.8/angular.min.js"></script> <script src="/static/angularjs/1.3.8/angular-resource.min.js"></script> <script src="/static/angular-ui-bootstrap/0.12.0/ui-bootstrap-tpls.min.js"></script> <div class="container"> <!-- --> <div layout:fragment="content"></div> </div> </body> </html>
angular.module('com.igumnov.common.example', ['ui.bootstrap', 'ngResource']) .factory('User', ['$resource', function ($resource) { // REST- User return $resource('/rest/user', {}, { list: { // method: 'GET', cache: false, isArray: true // }, add: { // method: 'POST', cache: false, isArray: false // }, delete: { // method: 'DELETE', cache: false, isArray: false // } }); }]) .controller('UserCtrl', function ($scope, User) { // UserCtrl $scope.users = User.list({}); // $scope.addUser = function (user) { // User.add({},user,function (data) { // REST- $scope.users = User.list({}); // , }, function (err) { alert(err.data.message); // , }); } $scope.deleteUser = function (user) { // User.delete({"userName" : user.userName},user,function (data) { // REST- $scope.users = User.list({}); // , }, function (err) { alert(err.data.message); // , }); } });
login.title=Login
Source: https://habr.com/ru/post/263749/
All Articles