├── .env.example ├── .gitattributes ├── .gitignore ├── app ├── Acl.php ├── Channels │ └── VoiceChannel.php ├── Console │ └── Kernel.php ├── Device.php ├── Events │ ├── OrderShipped.php │ └── ShippingStatusUpdated.php ├── Exceptions │ └── Handler.php ├── Http │ ├── Controllers │ │ ├── AclController.php │ │ ├── Auth │ │ │ ├── ForgotPasswordController.php │ │ │ ├── LoginController.php │ │ │ ├── RegisterController.php │ │ │ └── ResetPasswordController.php │ │ ├── Controller.php │ │ ├── DeviceController.php │ │ ├── HomeController.php │ │ └── UserController.php │ ├── Kernel.php │ ├── Middleware │ │ ├── EncryptCookies.php │ │ ├── RedirectIfAuthenticated.php │ │ └── VerifyCsrfToken.php │ └── Requests │ │ ├── RemoveDeviceRequest.php │ │ ├── StoreAclRequest.php │ │ ├── StoreDeviceRequest.php │ │ ├── StoreUserRequest.php │ │ ├── UpdateDeviceRequest.php │ │ └── UpdateUserRequest.php ├── Listeners │ ├── LogNotification.php │ ├── LogSentMessage.php │ ├── SendShipmentNotification.php │ └── SendShipmentStatusNotification.php ├── Mail │ └── OrderShipped.php ├── Message.php ├── Notifications │ └── InvoicePaid.php ├── Providers │ ├── AppServiceProvider.php │ ├── AuthServiceProvider.php │ ├── BroadcastServiceProvider.php │ ├── EventServiceProvider.php │ └── RouteServiceProvider.php └── User.php ├── artisan ├── bootstrap ├── app.php ├── autoload.php └── cache │ └── .gitignore ├── centos.sh ├── composer.json ├── composer.lock ├── config ├── app.php ├── auth.php ├── broadcasting.php ├── cache.php ├── compile.php ├── database.php ├── filesystems.php ├── mail.php ├── queue.php ├── services.php ├── session.php └── view.php ├── database ├── .gitignore ├── factories │ ├── DeviceFactory.php │ └── ModelFactory.php ├── migrations │ ├── .gitkeep │ ├── 2014_10_12_000000_create_users_table.php │ ├── 2014_10_12_100000_create_password_resets_table.php │ ├── 2016_12_19_035635_create_devices_table.php │ ├── 2016_12_19_184848_create_messages_table.php │ ├── 2016_12_19_185544_create_acls_table.php │ ├── 2016_12_21_200848_create_jobs_table.php │ ├── 2016_12_21_212946_create_failed_jobs_table.php │ ├── 2016_12_24_103112_create_cache_table.php │ └── 2016_12_27_204831_create_notifications_table.php └── seeds │ ├── .gitkeep │ ├── AclTableSeeder.php │ ├── DatabaseSeeder.php │ ├── DeviceTableSeeder.php │ ├── MessageTableSeeder.php │ └── UserTableSeeder.php ├── gulpfile.js ├── package.json ├── phpunit.xml ├── public ├── .htaccess ├── css │ ├── app.css │ └── app.css.map ├── favicon.ico ├── index.php ├── js │ ├── app.js │ ├── components │ │ ├── laydate-v1.1 │ │ │ ├── demo.html │ │ │ └── laydate │ │ │ │ ├── laydate.js │ │ │ │ ├── need │ │ │ │ └── laydate.css │ │ │ │ └── skins │ │ │ │ ├── dahong │ │ │ │ ├── icon.png │ │ │ │ └── laydate.css │ │ │ │ ├── default │ │ │ │ ├── icon.png │ │ │ │ └── laydate.css │ │ │ │ └── molv │ │ │ │ ├── icon.png │ │ │ │ └── laydate.css │ │ └── layer-v3.0.1 │ │ │ ├── demo.html │ │ │ └── layer │ │ │ ├── layer.js │ │ │ ├── mobile │ │ │ ├── layer.js │ │ │ └── need │ │ │ │ └── layer.css │ │ │ └── skin │ │ │ └── default │ │ │ ├── icon-ext.png │ │ │ ├── icon.png │ │ │ ├── layer.css │ │ │ ├── loading-0.gif │ │ │ ├── loading-1.gif │ │ │ └── loading-2.gif │ └── mqttws31.js ├── robots.txt └── web.config ├── readme.md ├── resources ├── assets │ ├── js │ │ ├── app.js │ │ ├── bootstrap.js │ │ └── components │ │ │ └── Example.vue │ └── sass │ │ ├── _variables.scss │ │ └── app.scss ├── lang │ ├── en │ │ ├── auth.php │ │ ├── pagination.php │ │ ├── passwords.php │ │ └── validation.php │ └── zh │ │ └── validation.php └── views │ ├── acl │ ├── create.blade.php │ ├── edit.blade.php │ └── index.blade.php │ ├── auth │ ├── login.blade.php │ ├── passwords │ │ ├── email.blade.php │ │ └── reset.blade.php │ └── register.blade.php │ ├── device │ ├── create.blade.php │ ├── edit.blade.php │ ├── index.blade.php │ ├── show.blade.php │ └── threshold.blade.php │ ├── emails │ └── foo.blade.php │ ├── errors │ └── 503.blade.php │ ├── home.blade.php │ ├── layouts │ └── app.blade.php │ ├── user │ ├── create.blade.php │ ├── edit.blade.php │ └── index.blade.php │ ├── vendor │ ├── .gitkeep │ ├── notifications │ │ ├── email-plain.blade.php │ │ └── email.blade.php │ └── pagination │ │ ├── bootstrap-4.blade.php │ │ ├── default.blade.php │ │ ├── simple-bootstrap-4.blade.php │ │ └── simple-default.blade.php │ └── welcome.blade.php ├── routes ├── api.php ├── console.php └── web.php ├── server.php ├── storage ├── app │ ├── .gitignore │ └── public │ │ └── .gitignore ├── framework │ ├── .gitignore │ ├── cache │ │ └── .gitignore │ ├── sessions │ │ └── .gitignore │ └── views │ │ └── .gitignore └── logs │ └── .gitignore ├── tests ├── ExampleTest.php └── TestCase.php └── ubuntu.sh /.env.example: -------------------------------------------------------------------------------- 1 | APP_ENV=local 2 | APP_KEY= 3 | APP_DEBUG=true 4 | APP_LOG_LEVEL=debug 5 | APP_URL=http://localhost 6 | 7 | DB_CONNECTION=mysql 8 | DB_HOST=127.0.0.1 9 | DB_PORT=3306 10 | DB_DATABASE=homestead 11 | DB_USERNAME=homestead 12 | DB_PASSWORD=secret 13 | 14 | BROADCAST_DRIVER=log 15 | CACHE_DRIVER=file 16 | SESSION_DRIVER=file 17 | QUEUE_DRIVER=sync 18 | 19 | REDIS_HOST=127.0.0.1 20 | REDIS_PASSWORD=null 21 | REDIS_PORT=6379 22 | 23 | MAIL_DRIVER=smtp 24 | MAIL_HOST=mailtrap.io 25 | MAIL_PORT=2525 26 | MAIL_USERNAME=null 27 | MAIL_PASSWORD=null 28 | MAIL_ENCRYPTION=null 29 | 30 | PUSHER_APP_ID= 31 | PUSHER_KEY= 32 | PUSHER_SECRET= 33 | -------------------------------------------------------------------------------- /.gitattributes: -------------------------------------------------------------------------------- 1 | * text=auto 2 | *.css linguist-vendored 3 | *.scss linguist-vendored 4 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | /node_modules 2 | /public/storage 3 | /vendor 4 | /.idea 5 | Homestead.json 6 | Homestead.yaml 7 | .env 8 | -------------------------------------------------------------------------------- /app/Acl.php: -------------------------------------------------------------------------------- 1 | allow ? '允许' : '阻止'; 19 | } 20 | 21 | public function getAccessStringAttribute() { 22 | switch ($this->access) { 23 | case 1: 24 | return '订阅'; 25 | case 2: 26 | return '发布'; 27 | case 3: 28 | return '订阅+发布'; 29 | default: 30 | return '未知'; 31 | break; 32 | } 33 | } 34 | } 35 | -------------------------------------------------------------------------------- /app/Channels/VoiceChannel.php: -------------------------------------------------------------------------------- 1 | toVoice($notifiable); 17 | 18 | // Send notification to the $notifiable instance... 19 | } 20 | } -------------------------------------------------------------------------------- /app/Console/Kernel.php: -------------------------------------------------------------------------------- 1 | command('inspire') 28 | // ->hourly(); 29 | } 30 | 31 | /** 32 | * Register the Closure based commands for the application. 33 | * 34 | * @return void 35 | */ 36 | protected function commands() 37 | { 38 | require base_path('routes/console.php'); 39 | } 40 | } 41 | -------------------------------------------------------------------------------- /app/Device.php: -------------------------------------------------------------------------------- 1 | expectsJson()) { 60 | return response()->json(['error' => 'Unauthenticated.'], 401); 61 | } 62 | 63 | return redirect()->guest('login'); 64 | } 65 | } 66 | -------------------------------------------------------------------------------- /app/Http/Controllers/AclController.php: -------------------------------------------------------------------------------- 1 | middleware('auth'); 12 | } 13 | /** 14 | * Display a listing of the resource. 15 | * 16 | * @return \Illuminate\Http\Response 17 | */ 18 | public function index() { 19 | $acls = Acl::paginate(20); 20 | return view('acl.index', ['acls' => $acls]); 21 | } 22 | 23 | /** 24 | * Show the form for creating a new resource. 25 | * 26 | * @return \Illuminate\Http\Response 27 | */ 28 | public function create() { 29 | return view('acl.create'); 30 | } 31 | 32 | /** 33 | * Store a newly created resource in storage. 34 | * 35 | * @param \Illuminate\Http\Request $request 36 | * @return \Illuminate\Http\Response 37 | */ 38 | public function store(StoreAclRequest $request) { 39 | Acl::create($request->all()); 40 | return redirect()->route('acl.index')->with('status', '权限设备添加成功'); 41 | } 42 | 43 | /** 44 | * Display the specified resource. 45 | * 46 | * @param int $id 47 | * @return \Illuminate\Http\Response 48 | */ 49 | public function show($id) { 50 | 51 | } 52 | 53 | /** 54 | * Show the form for editing the specified resource. 55 | * 56 | * @param int $id 57 | * @return \Illuminate\Http\Response 58 | */ 59 | public function edit($id) { 60 | $acl = Acl::findOrFail($id); 61 | return view('acl.edit', ['acl' => $acl]); 62 | } 63 | 64 | /** 65 | * Update the specified resource in storage. 66 | * 67 | * @param \Illuminate\Http\Request $request 68 | * @param int $id 69 | * @return \Illuminate\Http\Response 70 | */ 71 | public function update(StoreAclRequest $request, $id) { 72 | $acl = Acl::findOrFail($id); 73 | $acl->update($request->all()); 74 | return redirect()->route('acl.index')->with('status', '设备权限更新成功'); 75 | } 76 | 77 | /** 78 | * Remove the specified resource from storage. 79 | * 80 | * @param int $id 81 | * @return \Illuminate\Http\Response 82 | */ 83 | public function destroy($id) { 84 | Acl::destroy($id); 85 | return redirect()->route('acl.index')->with('status', '设备权限删除成功'); 86 | } 87 | } 88 | -------------------------------------------------------------------------------- /app/Http/Controllers/Auth/ForgotPasswordController.php: -------------------------------------------------------------------------------- 1 | middleware('guest'); 31 | } 32 | } 33 | -------------------------------------------------------------------------------- /app/Http/Controllers/Auth/LoginController.php: -------------------------------------------------------------------------------- 1 | middleware('guest', ['except' => 'logout']); 36 | } 37 | } 38 | -------------------------------------------------------------------------------- /app/Http/Controllers/Auth/RegisterController.php: -------------------------------------------------------------------------------- 1 | middleware('guest'); 38 | } 39 | 40 | /** 41 | * Get a validator for an incoming registration request. 42 | * 43 | * @param array $data 44 | * @return \Illuminate\Contracts\Validation\Validator 45 | */ 46 | protected function validator(array $data) { 47 | return Validator::make($data, [ 48 | 'name' => 'required|max:255', 49 | 'email' => 'required|email|max:255|unique:users', 50 | 'password' => 'required|min:6|confirmed', 51 | ]); 52 | } 53 | 54 | /** 55 | * Create a new user instance after a valid registration. 56 | * 57 | * @param array $data 58 | * @return User 59 | */ 60 | protected function create(array $data) { 61 | return User::create([ 62 | 'name' => $data['name'], 63 | 'email' => $data['email'], 64 | 'password' => bcrypt($data['password']), 65 | ]); 66 | } 67 | } 68 | -------------------------------------------------------------------------------- /app/Http/Controllers/Auth/ResetPasswordController.php: -------------------------------------------------------------------------------- 1 | middleware('guest'); 32 | } 33 | } 34 | -------------------------------------------------------------------------------- /app/Http/Controllers/Controller.php: -------------------------------------------------------------------------------- 1 | errors()->all(); 16 | } 17 | } 18 | -------------------------------------------------------------------------------- /app/Http/Controllers/DeviceController.php: -------------------------------------------------------------------------------- 1 | middleware('auth'); 20 | } 21 | 22 | /** 23 | * 设置设备默认阀值 24 | * @return void 25 | */ 26 | public function threshold(Request $request) { 27 | 28 | if ($request->isMethod('get')) { 29 | 30 | $threshold = Cache::get('device.threshold'); 31 | 32 | return view('device.threshold')->with('threshold', $threshold); 33 | 34 | } else if ($request->isMethod('put')) { 35 | 36 | $threshold = $request->input('threshold'); 37 | 38 | $rules = [ 39 | 'threshold' => 'regex:/\d+,\d+/', 40 | ]; 41 | 42 | $messages = [ 43 | 'threshold.regex' => '阀值不合法', 44 | ]; 45 | 46 | $validator = Validator::make($request->all(), $rules, $messages); 47 | 48 | if ($validator->fails()) { 49 | return redirect()->back()->withErrors($validator); 50 | } 51 | 52 | Cache::forever('device.threshold', $threshold); 53 | 54 | return redirect()->route('device.index')->with('status', '设备阀值设置成功'); 55 | } 56 | } 57 | 58 | /** 59 | * Display a listing of the resource. 60 | * 61 | * @return \Illuminate\Http\Response 62 | */ 63 | public function index() { 64 | $devices = Device::where([ 65 | 'is_superuser' => 0, 66 | 'user_id' => Auth::id(), 67 | ])->paginate(20); 68 | 69 | $superUser = Device::where('is_superuser', 1)->first(); 70 | $date = date('Y-m-d'); 71 | return view('device.index', ['devices' => $devices, 'date' => $date, 'superUser' => json_encode($superUser)]); 72 | } 73 | 74 | /** 75 | * Show the form for creating a new resource. 76 | * 77 | * @return \Illuminate\Http\Response 78 | */ 79 | public function create() { 80 | $faker = Faker::create(); 81 | 82 | $threshold = Cache::get('device.threshold'); 83 | 84 | if (!$threshold) { 85 | $threshold = '0.2,0.8'; 86 | } 87 | 88 | return view('device.create', ['username' => $faker->uuid, 'password' => $faker->password, 'salt' => $faker->word, 'threshold' => $threshold]); 89 | } 90 | 91 | /** 92 | * Store a newly created resource in storage. 93 | * 94 | * @param \Illuminate\Http\Request $request 95 | * @return \Illuminate\Http\Response 96 | */ 97 | public function store(StoreDeviceRequest $request) { 98 | $data = $request->all(); 99 | $data['user_id'] = Auth::id(); 100 | 101 | $device = Device::create($data); 102 | return redirect()->route('device.index')->with('status', '设备创建成功'); 103 | } 104 | 105 | /** 106 | * Display the specified resource. 107 | * 108 | * @param int $id 109 | * @return \Illuminate\Http\Response 110 | */ 111 | public function show(Device $device, $time) { 112 | 113 | $date = strtotime($time); 114 | $m = date('m', $date); 115 | $d = date('d', $date); 116 | $y = date('Y', $date); 117 | 118 | $begin = mktime(0, 0, 0, $m, $d, $y); 119 | $end = mktime(0, 0, 0, $m, $d + 1, $y) - 1; 120 | 121 | DB::statement('SET SESSION SQL_MODE = ""'); 122 | 123 | $sql = sprintf("SELECT status, at, sum / SUM(t.`sum`) as `percent` FROM (SELECT m.`payload` AS status, COUNT(m.`payload`) AS sum, FROM_UNIXTIME(`m`.`created_at`, '%%H') AS at FROM `messages` AS m WHERE `created_at` BETWEEN %s AND %s AND m.`from` = ? GROUP BY `at`, `payload` & (1 << 2)) AS t GROUP BY t.`at`", $begin, $end); 124 | 125 | $data = DB::select($sql, [$device->clientID]); 126 | 127 | // 获取最大、最小时间 128 | $ranges = DB::select('select MIN(`created_at`) AS min, MAX(`created_at`) AS max from `messages` where `from` = ?', [$device->clientID]); 129 | 130 | if (count($ranges) > 0) { 131 | $range = $ranges[0]; 132 | $range->min = date('Y-m-d', $range->min); 133 | $range->max = date('Y-m-d', $range->max); 134 | } else { 135 | $range = new StdClass(); 136 | $range->min = ''; 137 | $range->max = ''; 138 | } 139 | 140 | // threshold 141 | $thresholds = explode(',', $device->threshold); 142 | 143 | // 获取来自这台设备的状态信息 144 | $payload = Message::where('from', $device->clientID)->orderBy('id', 'desc')->pluck('payload')->first(); 145 | 146 | return view('device.show', [ 147 | 'data' => json_encode($data), 148 | 'device' => $device, 149 | 'time' => $time, 150 | 'range' => $range, 151 | 'threshold_min' => $thresholds[0], 152 | 'threshold_max' => $thresholds[1], 153 | 'payload' => $payload, 154 | ]); 155 | } 156 | 157 | /** 158 | * Show the form for editing the specified resource. 159 | * 160 | * @param int $id 161 | * @return \Illuminate\Http\Response 162 | */ 163 | public function edit($id) { 164 | $device = Device::find($id); 165 | return view('device.edit', ['device' => $device]); 166 | } 167 | 168 | /** 169 | * Update the specified resource in storage. 170 | * 171 | * @param \Illuminate\Http\Request $request 172 | * @param int $id 173 | * @return \Illuminate\Http\Response 174 | */ 175 | public function update(UpdateDeviceRequest $request, $id) { 176 | $device = Device::findOrFail($id); 177 | $affected = $device->update($request->all()); 178 | return redirect()->route('device.index')->with('status', '设备更新成功'); 179 | } 180 | 181 | /** 182 | * Remove the specified resource from storage. 183 | * 184 | * @param int $id 185 | * @return \Illuminate\Http\Response 186 | */ 187 | public function destroy(RemoveDeviceRequest $request, $id) { 188 | $device = Device::findOrFail($id); 189 | 190 | Device::destroy($device->id); 191 | 192 | // 删除所有消息 193 | Message::where('from', $device->clientID)->delete(); 194 | // 删除历史消息 195 | DB::table('message_history')->where('from', $device->clientID)->delete(); 196 | 197 | return redirect()->route('device.index')->with('status', '设备删除成功'); 198 | } 199 | } 200 | -------------------------------------------------------------------------------- /app/Http/Controllers/HomeController.php: -------------------------------------------------------------------------------- 1 | middleware('auth'); 8 | } 9 | 10 | public function index() { 11 | return view('home'); 12 | } 13 | 14 | public function bar($attribute, $value, $parameters, $validator) { 15 | return $value == 'bar'; 16 | } 17 | } 18 | -------------------------------------------------------------------------------- /app/Http/Controllers/UserController.php: -------------------------------------------------------------------------------- 1 | middleware('auth'); 13 | } 14 | /** 15 | * Display a listing of the resource. 16 | * 17 | * @return \Illuminate\Http\Response 18 | */ 19 | public function index() { 20 | $users = User::paginate(20); 21 | return view('user.index', ['users' => $users]); 22 | } 23 | 24 | /** 25 | * Show the form for creating a new resource. 26 | * 27 | * @return \Illuminate\Http\Response 28 | */ 29 | public function create() { 30 | return view('user.create'); 31 | } 32 | 33 | /** 34 | * Store a newly created resource in storage. 35 | * 36 | * @param \Illuminate\Http\Request $request 37 | * @return \Illuminate\Http\Response 38 | */ 39 | public function store(StoreUserRequest $request) { 40 | $data = $request->all(); 41 | $data['password'] = bcrypt($data['password']); 42 | $user = User::create($data); 43 | return redirect()->route('user.index')->with('status', '管理员创建成功'); 44 | } 45 | 46 | /** 47 | * Show the form for editing the specified resource. 48 | * 49 | * @param int $id 50 | * @return \Illuminate\Http\Response 51 | */ 52 | public function edit($id) { 53 | $user = User::find($id); 54 | return view('user.edit', ['user' => $user]); 55 | } 56 | 57 | /** 58 | * Update the specified resource in storage. 59 | * 60 | * @param \Illuminate\Http\Request $request 61 | * @param int $id 62 | * @return \Illuminate\Http\Response 63 | */ 64 | public function update(UpdateUserRequest $request, $id) { 65 | $user = User::findOrFail($id); 66 | $data = $request->all(); 67 | if ($data['password']) { 68 | $data['password'] = bcrypt($data['password']); 69 | } 70 | $user->update($data); 71 | return redirect()->route('user.index')->with('status', '管理员更新成功'); 72 | } 73 | /** 74 | * Remove the specified resource from storage. 75 | * 76 | * @param int $id 77 | * @return \Illuminate\Http\Response 78 | */ 79 | public function destroy($id) { 80 | 81 | $devices = Device::where('user_id', $id)->get(); 82 | $count = $devices->count(); 83 | 84 | if ($count > 0) { 85 | return redirect()->route('user.index')->with('status', '请先删除该用户的设备'); 86 | } 87 | 88 | $user = User::findOrFail($id); 89 | User::destroy($user->id); 90 | 91 | return redirect()->route('user.index')->with('status', '管理员删除成功'); 92 | } 93 | } 94 | -------------------------------------------------------------------------------- /app/Http/Kernel.php: -------------------------------------------------------------------------------- 1 | [ 26 | \App\Http\Middleware\EncryptCookies::class, 27 | \Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse::class, 28 | \Illuminate\Session\Middleware\StartSession::class, 29 | \Illuminate\View\Middleware\ShareErrorsFromSession::class, 30 | \App\Http\Middleware\VerifyCsrfToken::class, 31 | \Illuminate\Routing\Middleware\SubstituteBindings::class, 32 | ], 33 | 34 | 'api' => [ 35 | 'throttle:60,1', 36 | 'bindings', 37 | ], 38 | ]; 39 | 40 | /** 41 | * The application's route middleware. 42 | * 43 | * These middleware may be assigned to groups or used individually. 44 | * 45 | * @var array 46 | */ 47 | protected $routeMiddleware = [ 48 | 'auth' => \Illuminate\Auth\Middleware\Authenticate::class, 49 | 'auth.basic' => \Illuminate\Auth\Middleware\AuthenticateWithBasicAuth::class, 50 | 'bindings' => \Illuminate\Routing\Middleware\SubstituteBindings::class, 51 | 'can' => \Illuminate\Auth\Middleware\Authorize::class, 52 | 'guest' => \App\Http\Middleware\RedirectIfAuthenticated::class, 53 | 'throttle' => \Illuminate\Routing\Middleware\ThrottleRequests::class, 54 | ]; 55 | } 56 | -------------------------------------------------------------------------------- /app/Http/Middleware/EncryptCookies.php: -------------------------------------------------------------------------------- 1 | check()) { 19 | return redirect('/'); 20 | } 21 | 22 | return $next($request); 23 | } 24 | } 25 | -------------------------------------------------------------------------------- /app/Http/Middleware/VerifyCsrfToken.php: -------------------------------------------------------------------------------- 1 | route('device')); 17 | if (!$device || $device->user_id != Auth::id()) { 18 | return false; 19 | } 20 | return true; 21 | } 22 | 23 | /** 24 | * Get the validation rules that apply to the request. 25 | * 26 | * @return array 27 | */ 28 | public function rules() { 29 | return [ 30 | // 31 | ]; 32 | } 33 | } 34 | -------------------------------------------------------------------------------- /app/Http/Requests/StoreAclRequest.php: -------------------------------------------------------------------------------- 1 | 'ip|required_without:username,clientID,topic', 25 | 'allow' => 'required|in:0,1', 26 | 'username' => 'required_without:ipaddr,clientID,topic', 27 | 'clientID' => 'required_without:ipaddr,username,topic', 28 | 'access' => 'required|in:1,2,3', 29 | 'topic' => 'required_without:username,clientID,topic', 30 | ]; 31 | } 32 | } 33 | -------------------------------------------------------------------------------- /app/Http/Requests/StoreDeviceRequest.php: -------------------------------------------------------------------------------- 1 | '设备号必须填写', 11 | 'username.required' => '用户名必须填写', 12 | 'clientID.unique' => '设备号已被占用', 13 | 'username.unique' => '用户名已被占用', 14 | 'password.required' => '密码必须填写', 15 | 'threshold.regex' => '设备阀值格式有误', 16 | ]; 17 | } 18 | /** 19 | * Determine if the user is authorized to make this request. 20 | * 21 | * @return bool 22 | */ 23 | public function authorize() { 24 | return true; 25 | } 26 | 27 | /** 28 | * Get the validation rules that apply to the request. 29 | * 30 | * @return array 31 | */ 32 | public function rules() { 33 | return [ 34 | 'clientID' => 'required|unique:devices|max:100', 35 | 'name' => 'max:100', 36 | 'username' => 'required|unique:devices|max:100', 37 | 'password' => 'required', 38 | 'threshold' => 'regex:/\d+,\d+/', 39 | ]; 40 | } 41 | } 42 | -------------------------------------------------------------------------------- /app/Http/Requests/StoreUserRequest.php: -------------------------------------------------------------------------------- 1 | errors()->all(); 11 | } 12 | 13 | public function messages() { 14 | return [ 15 | 'name.required' => '用户名必须填写', 16 | 'email.required' => '邮箱必须填写', 17 | 'email.unique' => '邮箱已被占用', 18 | 'password.required' => '密码必须填写', 19 | ]; 20 | } 21 | /** 22 | * Determine if the user is authorized to make this request. 23 | * 24 | * @return bool 25 | */ 26 | public function authorize() { 27 | return true; 28 | } 29 | 30 | /** 31 | * Get the validation rules that apply to the request. 32 | * 33 | * @return array 34 | */ 35 | public function rules() { 36 | return [ 37 | 'name' => 'required|max:255', 38 | 'email' => 'required|email|max:255|unique:users', 39 | 'password' => 'required|min:6', 40 | ]; 41 | } 42 | } 43 | -------------------------------------------------------------------------------- /app/Http/Requests/UpdateDeviceRequest.php: -------------------------------------------------------------------------------- 1 | '设备号必须填写', 12 | 'username.required' => '用户名必须填写', 13 | 'clientID.unique' => '设备号已被占用', 14 | 'username.unique' => '用户名已被占用', 15 | 'password.required' => '密码必须填写', 16 | 'threshold.regex' => '设备阀值格式有误', 17 | ]; 18 | } 19 | /** 20 | * Determine if the user is authorized to make this request. 21 | * 22 | * @return bool 23 | */ 24 | public function authorize() { 25 | return true; 26 | } 27 | 28 | /** 29 | * Get the validation rules that apply to the request. 30 | * 31 | * @return array 32 | */ 33 | public function rules() { 34 | return [ 35 | 'clientID' => [ 36 | 'required', 37 | Rule::unique('devices')->ignore($this->route('device')), 38 | 'max:100', 39 | ], 40 | 'username' => [ 41 | 'required', 42 | Rule::unique('devices')->ignore($this->route('device')), 43 | 'max:100', 44 | ], 45 | 'password' => 'required', 46 | 'threshold' => 'regex:/\d+,\d+/', 47 | ]; 48 | } 49 | } 50 | -------------------------------------------------------------------------------- /app/Http/Requests/UpdateUserRequest.php: -------------------------------------------------------------------------------- 1 | 'required|max:255', 25 | 'email' => [ 26 | 'required', 27 | Rule::unique('users')->ignore($this->route('user')), 28 | 'max:255', 29 | ], 30 | 'password' => '', 31 | ]; 32 | } 33 | } 34 | -------------------------------------------------------------------------------- /app/Listeners/LogNotification.php: -------------------------------------------------------------------------------- 1 | channel); 25 | } 26 | } 27 | -------------------------------------------------------------------------------- /app/Listeners/LogSentMessage.php: -------------------------------------------------------------------------------- 1 | channel); 25 | } 26 | } 27 | -------------------------------------------------------------------------------- /app/Listeners/SendShipmentNotification.php: -------------------------------------------------------------------------------- 1 | user = $user; 23 | } 24 | 25 | /** 26 | * Build the message. 27 | * 28 | * @return $this 29 | */ 30 | public function build() { 31 | return $this 32 | ->from('389443626@qq.com') 33 | ->view('emails.foo'); 34 | } 35 | } 36 | -------------------------------------------------------------------------------- /app/Message.php: -------------------------------------------------------------------------------- 1 | subject('Notification Subject') 40 | ->line('The introduction to the notification.') 41 | ->action('Notification Action', 'https://laravel.com') 42 | ->line('Thank you for using our application!'); 43 | } 44 | 45 | /** 46 | * Get the Nexmo / SMS representation of the notification. 47 | * 48 | * @param mixed $notifiable 49 | * @return NexmoMessage 50 | */ 51 | public function toNexmo($notifiable) { 52 | return (new NexmoMessage) 53 | ->content('Your SMS message content'); 54 | } 55 | 56 | /** 57 | * Get the array representation of the notification. 58 | * 59 | * @param mixed $notifiable 60 | * @return array 61 | */ 62 | public function toBroadcast($notifiable) { 63 | return [ 64 | 'name' => 'Musikar', 65 | ]; 66 | } 67 | 68 | /** 69 | * Get the voice representation of the notification. 70 | * 71 | * @param mixed $notifiable 72 | * @return VoiceMessage 73 | */ 74 | public function toVoice($notifiable) { 75 | return [ 76 | 'name' => 'Musikar', 77 | ]; 78 | } 79 | } 80 | -------------------------------------------------------------------------------- /app/Providers/AppServiceProvider.php: -------------------------------------------------------------------------------- 1 | sql); 17 | }); 18 | } 19 | 20 | /** 21 | * Register any application services. 22 | * 23 | * @return void 24 | */ 25 | public function register() { 26 | // 27 | } 28 | } 29 | -------------------------------------------------------------------------------- /app/Providers/AuthServiceProvider.php: -------------------------------------------------------------------------------- 1 | 'App\Policies\ModelPolicy', 17 | ]; 18 | 19 | /** 20 | * Register any authentication / authorization services. 21 | * 22 | * @return void 23 | */ 24 | public function boot() 25 | { 26 | $this->registerPolicies(); 27 | 28 | // 29 | } 30 | } 31 | -------------------------------------------------------------------------------- /app/Providers/BroadcastServiceProvider.php: -------------------------------------------------------------------------------- 1 | id === (int) $userId; 22 | }); 23 | } 24 | } 25 | -------------------------------------------------------------------------------- /app/Providers/EventServiceProvider.php: -------------------------------------------------------------------------------- 1 | [ 17 | 'App\Listeners\LogSentMessage', 18 | ], 19 | 'Illuminate\Notifications\Events\NotificationSent' => [ 20 | 'App\Listeners\LogNotification', 21 | ], 22 | 'App\Events\OrderShipped' => [ 23 | 'App\Listeners\SendShipmentNotification', 24 | ], 25 | 'App\Events\ShippingStatusUpdated' => [ 26 | 27 | ], 28 | ]; 29 | 30 | /** 31 | * Register any events for your application. 32 | * 33 | * @return void 34 | */ 35 | public function boot() { 36 | parent::boot(); 37 | 38 | Broadcast::channel('test/topic', function ($user, $orderId) { 39 | return true; 40 | }); 41 | } 42 | } 43 | -------------------------------------------------------------------------------- /app/Providers/RouteServiceProvider.php: -------------------------------------------------------------------------------- 1 | mapApiRoutes(); 39 | 40 | $this->mapWebRoutes(); 41 | 42 | // 43 | } 44 | 45 | /** 46 | * Define the "web" routes for the application. 47 | * 48 | * These routes all receive session state, CSRF protection, etc. 49 | * 50 | * @return void 51 | */ 52 | protected function mapWebRoutes() 53 | { 54 | Route::group([ 55 | 'middleware' => 'web', 56 | 'namespace' => $this->namespace, 57 | ], function ($router) { 58 | require base_path('routes/web.php'); 59 | }); 60 | } 61 | 62 | /** 63 | * Define the "api" routes for the application. 64 | * 65 | * These routes are typically stateless. 66 | * 67 | * @return void 68 | */ 69 | protected function mapApiRoutes() 70 | { 71 | Route::group([ 72 | 'middleware' => 'api', 73 | 'namespace' => $this->namespace, 74 | 'prefix' => 'api', 75 | ], function ($router) { 76 | require base_path('routes/api.php'); 77 | }); 78 | } 79 | } 80 | -------------------------------------------------------------------------------- /app/User.php: -------------------------------------------------------------------------------- 1 | email; 36 | } 37 | } 38 | -------------------------------------------------------------------------------- /artisan: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env php 2 | make(Illuminate\Contracts\Console\Kernel::class); 32 | 33 | $status = $kernel->handle( 34 | $input = new Symfony\Component\Console\Input\ArgvInput, 35 | new Symfony\Component\Console\Output\ConsoleOutput 36 | ); 37 | 38 | /* 39 | |-------------------------------------------------------------------------- 40 | | Shutdown The Application 41 | |-------------------------------------------------------------------------- 42 | | 43 | | Once Artisan has finished running. We will fire off the shutdown events 44 | | so that any final work may be done by the application before we shut 45 | | down the process. This is the last thing to happen to the request. 46 | | 47 | */ 48 | 49 | $kernel->terminate($input, $status); 50 | 51 | exit($status); 52 | -------------------------------------------------------------------------------- /bootstrap/app.php: -------------------------------------------------------------------------------- 1 | singleton( 30 | Illuminate\Contracts\Http\Kernel::class, 31 | App\Http\Kernel::class 32 | ); 33 | 34 | $app->singleton( 35 | Illuminate\Contracts\Console\Kernel::class, 36 | App\Console\Kernel::class 37 | ); 38 | 39 | $app->singleton( 40 | Illuminate\Contracts\Debug\ExceptionHandler::class, 41 | App\Exceptions\Handler::class 42 | ); 43 | 44 | /* 45 | |-------------------------------------------------------------------------- 46 | | Return The Application 47 | |-------------------------------------------------------------------------- 48 | | 49 | | This script returns the application instance. The instance is given to 50 | | the calling script so we can separate the building of the instances 51 | | from the actual running of the application and sending responses. 52 | | 53 | */ 54 | 55 | return $app; 56 | -------------------------------------------------------------------------------- /bootstrap/autoload.php: -------------------------------------------------------------------------------- 1 | =5.6.4", 9 | "laravel/framework": "5.3.*", 10 | "guzzlehttp/guzzle": "^6.2", 11 | "predis/predis": "^1.1" 12 | }, 13 | "require-dev": { 14 | "fzaninotto/faker": "~1.4", 15 | "mockery/mockery": "0.9.*", 16 | "phpunit/phpunit": "~5.0", 17 | "symfony/css-selector": "3.1.*", 18 | "symfony/dom-crawler": "3.1.*" 19 | }, 20 | "autoload": { 21 | "classmap": [ 22 | "database" 23 | ], 24 | "psr-4": { 25 | "App\\": "app/" 26 | } 27 | }, 28 | "autoload-dev": { 29 | "classmap": [ 30 | "tests/TestCase.php" 31 | ] 32 | }, 33 | "scripts": { 34 | "post-root-package-install": [ 35 | "php -r \"file_exists('.env') || copy('.env.example', '.env');\"" 36 | ], 37 | "post-create-project-cmd": [ 38 | "php artisan key:generate" 39 | ], 40 | "post-install-cmd": [ 41 | "Illuminate\\Foundation\\ComposerScripts::postInstall", 42 | "php artisan optimize" 43 | ], 44 | "post-update-cmd": [ 45 | "Illuminate\\Foundation\\ComposerScripts::postUpdate", 46 | "php artisan optimize" 47 | ] 48 | }, 49 | "config": { 50 | "preferred-install": "dist" 51 | } 52 | } 53 | -------------------------------------------------------------------------------- /config/auth.php: -------------------------------------------------------------------------------- 1 | [ 17 | 'guard' => 'web', 18 | 'passwords' => 'users', 19 | ], 20 | 21 | /* 22 | |-------------------------------------------------------------------------- 23 | | Authentication Guards 24 | |-------------------------------------------------------------------------- 25 | | 26 | | Next, you may define every authentication guard for your application. 27 | | Of course, a great default configuration has been defined for you 28 | | here which uses session storage and the Eloquent user provider. 29 | | 30 | | All authentication drivers have a user provider. This defines how the 31 | | users are actually retrieved out of your database or other storage 32 | | mechanisms used by this application to persist your user's data. 33 | | 34 | | Supported: "session", "token" 35 | | 36 | */ 37 | 38 | 'guards' => [ 39 | 'web' => [ 40 | 'driver' => 'session', 41 | 'provider' => 'users', 42 | ], 43 | 44 | 'api' => [ 45 | 'driver' => 'token', 46 | 'provider' => 'users', 47 | ], 48 | ], 49 | 50 | /* 51 | |-------------------------------------------------------------------------- 52 | | User Providers 53 | |-------------------------------------------------------------------------- 54 | | 55 | | All authentication drivers have a user provider. This defines how the 56 | | users are actually retrieved out of your database or other storage 57 | | mechanisms used by this application to persist your user's data. 58 | | 59 | | If you have multiple user tables or models you may configure multiple 60 | | sources which represent each model / table. These sources may then 61 | | be assigned to any extra authentication guards you have defined. 62 | | 63 | | Supported: "database", "eloquent" 64 | | 65 | */ 66 | 67 | 'providers' => [ 68 | 'users' => [ 69 | 'driver' => 'eloquent', 70 | 'model' => App\User::class, 71 | ], 72 | 73 | // 'users' => [ 74 | // 'driver' => 'database', 75 | // 'table' => 'users', 76 | // ], 77 | ], 78 | 79 | /* 80 | |-------------------------------------------------------------------------- 81 | | Resetting Passwords 82 | |-------------------------------------------------------------------------- 83 | | 84 | | You may specify multiple password reset configurations if you have more 85 | | than one user table or model in the application and you want to have 86 | | separate password reset settings based on the specific user types. 87 | | 88 | | The expire time is the number of minutes that the reset token should be 89 | | considered valid. This security feature keeps tokens short-lived so 90 | | they have less time to be guessed. You may change this as needed. 91 | | 92 | */ 93 | 94 | 'passwords' => [ 95 | 'users' => [ 96 | 'provider' => 'users', 97 | 'table' => 'password_resets', 98 | 'expire' => 60, 99 | ], 100 | ], 101 | 102 | ]; 103 | -------------------------------------------------------------------------------- /config/broadcasting.php: -------------------------------------------------------------------------------- 1 | env('BROADCAST_DRIVER', 'null'), 19 | 20 | /* 21 | |-------------------------------------------------------------------------- 22 | | Broadcast Connections 23 | |-------------------------------------------------------------------------- 24 | | 25 | | Here you may define all of the broadcast connections that will be used 26 | | to broadcast events to other systems or over websockets. Samples of 27 | | each available type of connection are provided inside this array. 28 | | 29 | */ 30 | 31 | 'connections' => [ 32 | 33 | 'pusher' => [ 34 | 'driver' => 'pusher', 35 | 'key' => env('PUSHER_KEY'), 36 | 'secret' => env('PUSHER_SECRET'), 37 | 'app_id' => env('PUSHER_APP_ID'), 38 | 'options' => [ 39 | // 40 | ], 41 | ], 42 | 43 | 'redis' => [ 44 | 'driver' => 'redis', 45 | 'connection' => 'default', 46 | ], 47 | 48 | 'log' => [ 49 | 'driver' => 'log', 50 | ], 51 | 52 | 'null' => [ 53 | 'driver' => 'null', 54 | ], 55 | 56 | ], 57 | 58 | ]; 59 | -------------------------------------------------------------------------------- /config/cache.php: -------------------------------------------------------------------------------- 1 | env('CACHE_DRIVER', 'file'), 19 | 20 | /* 21 | |-------------------------------------------------------------------------- 22 | | Cache Stores 23 | |-------------------------------------------------------------------------- 24 | | 25 | | Here you may define all of the cache "stores" for your application as 26 | | well as their drivers. You may even define multiple stores for the 27 | | same cache driver to group types of items stored in your caches. 28 | | 29 | */ 30 | 31 | 'stores' => [ 32 | 33 | 'apc' => [ 34 | 'driver' => 'apc', 35 | ], 36 | 37 | 'array' => [ 38 | 'driver' => 'array', 39 | ], 40 | 41 | 'database' => [ 42 | 'driver' => 'database', 43 | 'table' => 'cache', 44 | 'connection' => null, 45 | ], 46 | 47 | 'file' => [ 48 | 'driver' => 'file', 49 | 'path' => storage_path('framework/cache'), 50 | ], 51 | 52 | 'memcached' => [ 53 | 'driver' => 'memcached', 54 | 'persistent_id' => env('MEMCACHED_PERSISTENT_ID'), 55 | 'sasl' => [ 56 | env('MEMCACHED_USERNAME'), 57 | env('MEMCACHED_PASSWORD'), 58 | ], 59 | 'options' => [ 60 | // Memcached::OPT_CONNECT_TIMEOUT => 2000, 61 | ], 62 | 'servers' => [ 63 | [ 64 | 'host' => env('MEMCACHED_HOST', '127.0.0.1'), 65 | 'port' => env('MEMCACHED_PORT', 11211), 66 | 'weight' => 100, 67 | ], 68 | ], 69 | ], 70 | 71 | 'redis' => [ 72 | 'driver' => 'redis', 73 | 'connection' => 'default', 74 | ], 75 | 76 | ], 77 | 78 | /* 79 | |-------------------------------------------------------------------------- 80 | | Cache Key Prefix 81 | |-------------------------------------------------------------------------- 82 | | 83 | | When utilizing a RAM based store such as APC or Memcached, there might 84 | | be other applications utilizing the same cache. So, we'll specify a 85 | | value to get prefixed to all our keys so we can avoid collisions. 86 | | 87 | */ 88 | 89 | 'prefix' => 'laravel', 90 | 91 | ]; 92 | -------------------------------------------------------------------------------- /config/compile.php: -------------------------------------------------------------------------------- 1 | [ 17 | // 18 | ], 19 | 20 | /* 21 | |-------------------------------------------------------------------------- 22 | | Compiled File Providers 23 | |-------------------------------------------------------------------------- 24 | | 25 | | Here you may list service providers which define a "compiles" function 26 | | that returns additional files that should be compiled, providing an 27 | | easy way to get common files from any packages you are utilizing. 28 | | 29 | */ 30 | 31 | 'providers' => [ 32 | // 33 | ], 34 | 35 | ]; 36 | -------------------------------------------------------------------------------- /config/database.php: -------------------------------------------------------------------------------- 1 | PDO::FETCH_OBJ, 17 | 18 | /* 19 | |-------------------------------------------------------------------------- 20 | | Default Database Connection Name 21 | |-------------------------------------------------------------------------- 22 | | 23 | | Here you may specify which of the database connections below you wish 24 | | to use as your default connection for all database work. Of course 25 | | you may use many connections at once using the Database library. 26 | | 27 | */ 28 | 29 | 'default' => env('DB_CONNECTION', 'mysql'), 30 | 31 | /* 32 | |-------------------------------------------------------------------------- 33 | | Database Connections 34 | |-------------------------------------------------------------------------- 35 | | 36 | | Here are each of the database connections setup for your application. 37 | | Of course, examples of configuring each database platform that is 38 | | supported by Laravel is shown below to make development simple. 39 | | 40 | | 41 | | All database work in Laravel is done through the PHP PDO facilities 42 | | so make sure you have the driver for your particular database of 43 | | choice installed on your machine before you begin development. 44 | | 45 | */ 46 | 47 | 'connections' => [ 48 | 49 | 'sqlite' => [ 50 | 'driver' => 'sqlite', 51 | 'database' => env('DB_DATABASE', database_path('database.sqlite')), 52 | 'prefix' => '', 53 | ], 54 | 55 | 'mysql' => [ 56 | 'driver' => 'mysql', 57 | 'host' => env('DB_HOST', 'localhost'), 58 | 'port' => env('DB_PORT', '3306'), 59 | 'database' => env('DB_DATABASE', 'forge'), 60 | 'username' => env('DB_USERNAME', 'forge'), 61 | 'password' => env('DB_PASSWORD', ''), 62 | 'charset' => 'utf8', 63 | 'collation' => 'utf8_unicode_ci', 64 | 'prefix' => '', 65 | 'strict' => true, 66 | 'engine' => null, 67 | ], 68 | 69 | 'pgsql' => [ 70 | 'driver' => 'pgsql', 71 | 'host' => env('DB_HOST', 'localhost'), 72 | 'port' => env('DB_PORT', '5432'), 73 | 'database' => env('DB_DATABASE', 'forge'), 74 | 'username' => env('DB_USERNAME', 'forge'), 75 | 'password' => env('DB_PASSWORD', ''), 76 | 'charset' => 'utf8', 77 | 'prefix' => '', 78 | 'schema' => 'public', 79 | 'sslmode' => 'prefer', 80 | ], 81 | 82 | ], 83 | 84 | /* 85 | |-------------------------------------------------------------------------- 86 | | Migration Repository Table 87 | |-------------------------------------------------------------------------- 88 | | 89 | | This table keeps track of all the migrations that have already run for 90 | | your application. Using this information, we can determine which of 91 | | the migrations on disk haven't actually been run in the database. 92 | | 93 | */ 94 | 95 | 'migrations' => 'migrations', 96 | 97 | /* 98 | |-------------------------------------------------------------------------- 99 | | Redis Databases 100 | |-------------------------------------------------------------------------- 101 | | 102 | | Redis is an open source, fast, and advanced key-value store that also 103 | | provides a richer set of commands than a typical key-value systems 104 | | such as APC or Memcached. Laravel makes it easy to dig right in. 105 | | 106 | */ 107 | 108 | 'redis' => [ 109 | 110 | // 'client' => 'predis', 111 | 'client' => 'phpredis', 112 | 113 | 'cluster' => false, 114 | 115 | 'default' => [ 116 | 'host' => env('REDIS_HOST', 'localhost'), 117 | 'password' => env('REDIS_PASSWORD', null), 118 | 'port' => env('REDIS_PORT', 6379), 119 | 'database' => 0, 120 | 'read_write_timeout' => 60, 121 | /* phpredis only */ 122 | 'read_timeout' => 60, 123 | 'timeout' => 60, 124 | 'persistent' => true, 125 | 'prefix' => 'pre_', 126 | ], 127 | 128 | 'foo' => [ 129 | 'host' => env('REDIS_HOST', 'localhost'), 130 | 'password' => env('REDIS_PASSWORD', null), 131 | 'port' => env('REDIS_PORT', 6379), 132 | 'database' => 0, 133 | 'read_write_timeout' => 60, 134 | /* phpredis only */ 135 | 'read_timeout' => 60, 136 | 'timeout' => 60, 137 | 'persistent' => true, 138 | 'prefix' => 'pre_', 139 | ], 140 | 141 | ], 142 | 143 | ]; 144 | -------------------------------------------------------------------------------- /config/filesystems.php: -------------------------------------------------------------------------------- 1 | 'local', 19 | 20 | /* 21 | |-------------------------------------------------------------------------- 22 | | Default Cloud Filesystem Disk 23 | |-------------------------------------------------------------------------- 24 | | 25 | | Many applications store files both locally and in the cloud. For this 26 | | reason, you may specify a default "cloud" driver here. This driver 27 | | will be bound as the Cloud disk implementation in the container. 28 | | 29 | */ 30 | 31 | 'cloud' => 's3', 32 | 33 | /* 34 | |-------------------------------------------------------------------------- 35 | | Filesystem Disks 36 | |-------------------------------------------------------------------------- 37 | | 38 | | Here you may configure as many filesystem "disks" as you wish, and you 39 | | may even configure multiple disks of the same driver. Defaults have 40 | | been setup for each driver as an example of the required options. 41 | | 42 | */ 43 | 44 | 'disks' => [ 45 | 46 | 'local' => [ 47 | 'driver' => 'local', 48 | 'root' => storage_path('app'), 49 | ], 50 | 51 | 'public' => [ 52 | 'driver' => 'local', 53 | 'root' => storage_path('app/public'), 54 | 'visibility' => 'public', 55 | ], 56 | 57 | 's3' => [ 58 | 'driver' => 's3', 59 | 'key' => 'your-key', 60 | 'secret' => 'your-secret', 61 | 'region' => 'your-region', 62 | 'bucket' => 'your-bucket', 63 | ], 64 | 65 | 'ftp' => [ 66 | 'driver' => 'ftp', 67 | 'host' => 'localhost', 68 | 'username' => 'apple', 69 | 'password' => '1', 70 | 71 | // Optional FTP Settings... 72 | // 'port' => 21, 73 | // 'root' => '', 74 | // 'passive' => true, 75 | // 'ssl' => true, 76 | // 'timeout' => 30, 77 | ], 78 | ], 79 | 80 | ]; 81 | -------------------------------------------------------------------------------- /config/mail.php: -------------------------------------------------------------------------------- 1 | env('MAIL_DRIVER', 'smtp'), 20 | 21 | /* 22 | |-------------------------------------------------------------------------- 23 | | SMTP Host Address 24 | |-------------------------------------------------------------------------- 25 | | 26 | | Here you may provide the host address of the SMTP server used by your 27 | | applications. A default option is provided that is compatible with 28 | | the Mailgun mail service which will provide reliable deliveries. 29 | | 30 | */ 31 | 32 | 'host' => env('MAIL_HOST', 'smtp.mailgun.org'), 33 | 34 | /* 35 | |-------------------------------------------------------------------------- 36 | | SMTP Host Port 37 | |-------------------------------------------------------------------------- 38 | | 39 | | This is the SMTP port used by your application to deliver e-mails to 40 | | users of the application. Like the host we have set this value to 41 | | stay compatible with the Mailgun e-mail application by default. 42 | | 43 | */ 44 | 45 | 'port' => env('MAIL_PORT', 587), 46 | 47 | /* 48 | |-------------------------------------------------------------------------- 49 | | Global "From" Address 50 | |-------------------------------------------------------------------------- 51 | | 52 | | You may wish for all e-mails sent by your application to be sent from 53 | | the same address. Here, you may specify a name and address that is 54 | | used globally for all e-mails that are sent by your application. 55 | | 56 | */ 57 | 58 | 'from' => [ 59 | 'address' => '389443626@qq.com', 60 | 'name' => 'Laravel', 61 | ], 62 | 63 | /* 64 | |-------------------------------------------------------------------------- 65 | | E-Mail Encryption Protocol 66 | |-------------------------------------------------------------------------- 67 | | 68 | | Here you may specify the encryption protocol that should be used when 69 | | the application send e-mail messages. A sensible default using the 70 | | transport layer security protocol should provide great security. 71 | | 72 | */ 73 | 74 | 'encryption' => env('MAIL_ENCRYPTION', 'tls'), 75 | 76 | /* 77 | |-------------------------------------------------------------------------- 78 | | SMTP Server Username 79 | |-------------------------------------------------------------------------- 80 | | 81 | | If your SMTP server requires a username for authentication, you should 82 | | set it here. This will get used to authenticate with your server on 83 | | connection. You may also set the "password" value below this one. 84 | | 85 | */ 86 | 87 | 'username' => env('MAIL_USERNAME'), 88 | 89 | /* 90 | |-------------------------------------------------------------------------- 91 | | SMTP Server Password 92 | |-------------------------------------------------------------------------- 93 | | 94 | | Here you may set the password required by your SMTP server to send out 95 | | messages from your application. This will be given to the server on 96 | | connection so that the application will be able to send messages. 97 | | 98 | */ 99 | 100 | 'password' => env('MAIL_PASSWORD'), 101 | 102 | /* 103 | |-------------------------------------------------------------------------- 104 | | Sendmail System Path 105 | |-------------------------------------------------------------------------- 106 | | 107 | | When using the "sendmail" driver to send e-mails, we will need to know 108 | | the path to where Sendmail lives on this server. A default path has 109 | | been provided here, which will work well on most of your systems. 110 | | 111 | */ 112 | 113 | 'sendmail' => '/usr/sbin/sendmail -bs', 114 | 115 | ]; 116 | -------------------------------------------------------------------------------- /config/queue.php: -------------------------------------------------------------------------------- 1 | env('QUEUE_DRIVER', 'sync'), 19 | 20 | /* 21 | |-------------------------------------------------------------------------- 22 | | Queue Connections 23 | |-------------------------------------------------------------------------- 24 | | 25 | | Here you may configure the connection information for each server that 26 | | is used by your application. A default configuration has been added 27 | | for each back-end shipped with Laravel. You are free to add more. 28 | | 29 | */ 30 | 31 | 'connections' => [ 32 | 33 | 'sync' => [ 34 | 'driver' => 'sync', 35 | ], 36 | 37 | 'database' => [ 38 | 'driver' => 'database', 39 | 'table' => 'jobs', 40 | 'queue' => 'default', 41 | 'retry_after' => 10, 42 | ], 43 | 44 | 'beanstalkd' => [ 45 | 'driver' => 'beanstalkd', 46 | 'host' => 'localhost', 47 | 'queue' => 'default', 48 | 'retry_after' => 90, 49 | ], 50 | 51 | 'sqs' => [ 52 | 'driver' => 'sqs', 53 | 'key' => 'your-public-key', 54 | 'secret' => 'your-secret-key', 55 | 'prefix' => 'https://sqs.us-east-1.amazonaws.com/your-account-id', 56 | 'queue' => 'your-queue-name', 57 | 'region' => 'us-east-1', 58 | ], 59 | 60 | 'redis' => [ 61 | 'driver' => 'redis', 62 | 'connection' => 'default', 63 | 'queue' => 'default', 64 | 'retry_after' => 90, 65 | ], 66 | 67 | ], 68 | 69 | /* 70 | |-------------------------------------------------------------------------- 71 | | Failed Queue Jobs 72 | |-------------------------------------------------------------------------- 73 | | 74 | | These options configure the behavior of failed queue job logging so you 75 | | can control which database and table are used to store the jobs that 76 | | have failed. You may change them to any database / table you wish. 77 | | 78 | */ 79 | 80 | 'failed' => [ 81 | 'database' => env('DB_CONNECTION', 'mysql'), 82 | 'table' => 'failed_jobs', 83 | ], 84 | 85 | ]; 86 | -------------------------------------------------------------------------------- /config/services.php: -------------------------------------------------------------------------------- 1 | [ 18 | 'domain' => env('MAILGUN_DOMAIN'), 19 | 'secret' => env('MAILGUN_SECRET'), 20 | ], 21 | 22 | 'ses' => [ 23 | 'key' => env('SES_KEY'), 24 | 'secret' => env('SES_SECRET'), 25 | 'region' => 'us-east-1', 26 | ], 27 | 28 | 'sparkpost' => [ 29 | 'secret' => env('SPARKPOST_SECRET'), 30 | ], 31 | 32 | 'stripe' => [ 33 | 'model' => App\User::class, 34 | 'key' => env('STRIPE_KEY'), 35 | 'secret' => env('STRIPE_SECRET'), 36 | ], 37 | 38 | ]; 39 | -------------------------------------------------------------------------------- /config/view.php: -------------------------------------------------------------------------------- 1 | [ 17 | realpath(base_path('resources/views')), 18 | ], 19 | 20 | /* 21 | |-------------------------------------------------------------------------- 22 | | Compiled View Path 23 | |-------------------------------------------------------------------------- 24 | | 25 | | This option determines where all the compiled Blade templates will be 26 | | stored for your application. Typically, this is within the storage 27 | | directory. However, as usual, you are free to change this value. 28 | | 29 | */ 30 | 31 | 'compiled' => realpath(storage_path('framework/views')), 32 | 33 | ]; 34 | -------------------------------------------------------------------------------- /database/.gitignore: -------------------------------------------------------------------------------- 1 | *.sqlite 2 | -------------------------------------------------------------------------------- /database/factories/DeviceFactory.php: -------------------------------------------------------------------------------- 1 | define(App\Device::class, function (Faker\Generator $faker) { 4 | 5 | return [ 6 | 'user_id' => 1, 7 | 'clientID' => $faker->macAddress, 8 | 'username' => $faker->uuid, 9 | 'password' => $faker->password, 10 | 'salt' => $faker->word, 11 | 'created_at' => $faker->dateTimeThisMonth, 12 | 'updated_at' => $faker->dateTimeThisMonth, 13 | ]; 14 | }); 15 | 16 | $factory->define(App\Message::class, function (Faker\Generator $faker) { 17 | 18 | return [ 19 | 'from' => App\Device::find(1)->clientID, 20 | 'topic' => 'device/status', 21 | 'payload' => 'on', 22 | 'created_at' => time() + 3600, 23 | ]; 24 | }); -------------------------------------------------------------------------------- /database/factories/ModelFactory.php: -------------------------------------------------------------------------------- 1 | define(App\User::class, function (Faker\Generator $faker) { 15 | static $password; 16 | 17 | return [ 18 | 'name' => $faker->name, 19 | 'email' => $faker->unique()->safeEmail, 20 | 'password' => $password ?: $password = bcrypt('123456'), 21 | 'remember_token' => str_random(10), 22 | ]; 23 | }); 24 | -------------------------------------------------------------------------------- /database/migrations/.gitkeep: -------------------------------------------------------------------------------- 1 | 2 | -------------------------------------------------------------------------------- /database/migrations/2014_10_12_000000_create_users_table.php: -------------------------------------------------------------------------------- 1 | increments('id'); 16 | $table->string('name'); 17 | $table->string('email')->unique(); 18 | $table->string('password'); 19 | $table->rememberToken(); 20 | $table->timestamps(); 21 | }); 22 | } 23 | 24 | /** 25 | * Reverse the migrations. 26 | * 27 | * @return void 28 | */ 29 | public function down() { 30 | Schema::drop('users'); 31 | } 32 | } 33 | -------------------------------------------------------------------------------- /database/migrations/2014_10_12_100000_create_password_resets_table.php: -------------------------------------------------------------------------------- 1 | string('email')->index(); 18 | $table->string('token')->index(); 19 | $table->timestamp('created_at')->nullable(); 20 | }); 21 | } 22 | 23 | /** 24 | * Reverse the migrations. 25 | * 26 | * @return void 27 | */ 28 | public function down() 29 | { 30 | Schema::drop('password_resets'); 31 | } 32 | } 33 | -------------------------------------------------------------------------------- /database/migrations/2016_12_19_035635_create_devices_table.php: -------------------------------------------------------------------------------- 1 | increments('id'); 16 | // 拥有设备的用户 17 | $table->integer('user_id')->index(); 18 | // 用户自定义设备名称 19 | $table->string('name', 100); 20 | // 设备登陆验证 21 | $table->string('clientID', 100)->unique(); 22 | $table->string('username', 100); 23 | $table->string('password', 100); 24 | // 设备阀值 25 | $table->string('threshold'); 26 | // 27 | $table->string('salt', 20); 28 | // 是否为超级管理员, 超级管理员可以给其他设备发送控制指令 29 | $table->tinyInteger('is_superuser')->default(0); 30 | // 设备连接状态 31 | $table->tinyInteger('status')->default(0); 32 | $table->timestamps(); 33 | }); 34 | } 35 | 36 | /** 37 | * Reverse the migrations. 38 | * 39 | * @return void 40 | */ 41 | public function down() { 42 | Schema::dropIfExists('devices'); 43 | } 44 | } 45 | -------------------------------------------------------------------------------- /database/migrations/2016_12_19_184848_create_messages_table.php: -------------------------------------------------------------------------------- 1 | bigIncrements('id'); 16 | $table->string('from', 100)->default('')->index(); 17 | $table->string('topic', 100)->default(''); 18 | $table->string('payload', 100)->default('')->index(); 19 | $table->integer('created_at')->index(); 20 | }); 21 | 22 | Schema::create('message_history', function (Blueprint $table) { 23 | $table->bigIncrements('id'); 24 | $table->string('from', 100)->default('')->index(); 25 | $table->string('topic', 100)->default(''); 26 | $table->string('payload', 100)->default('')->index(); 27 | $table->integer('created_at')->index(); 28 | }); 29 | } 30 | 31 | /** 32 | * Reverse the migrations. 33 | * 34 | * @return void 35 | */ 36 | public function down() { 37 | Schema::dropIfExists('messages'); 38 | Schema::dropIfExists('message_history'); 39 | } 40 | } 41 | -------------------------------------------------------------------------------- /database/migrations/2016_12_19_185544_create_acls_table.php: -------------------------------------------------------------------------------- 1 | increments('id'); 16 | // 0: deny, 1: allow 17 | $table->tinyInteger('allow'); 18 | $table->string('ipaddr', 60); 19 | $table->string('username', 100); 20 | $table->string('clientID', 100); 21 | // 1: subscribe, 2: publish, 3: pubsub 22 | $table->tinyInteger('access'); 23 | $table->string('topic', 100); 24 | $table->timestamps(); 25 | }); 26 | } 27 | 28 | /** 29 | * Reverse the migrations. 30 | * 31 | * @return void 32 | */ 33 | public function down() { 34 | Schema::dropIfExists('acls'); 35 | } 36 | } 37 | -------------------------------------------------------------------------------- /database/migrations/2016_12_21_200848_create_jobs_table.php: -------------------------------------------------------------------------------- 1 | bigIncrements('id'); 16 | $table->string('queue'); 17 | $table->longText('payload'); 18 | $table->tinyInteger('attempts')->unsigned(); 19 | $table->unsignedInteger('reserved_at')->nullable(); 20 | $table->unsignedInteger('available_at'); 21 | $table->unsignedInteger('created_at'); 22 | $table->index(['queue', 'reserved_at']); 23 | }); 24 | } 25 | 26 | /** 27 | * Reverse the migrations. 28 | * 29 | * @return void 30 | */ 31 | public function down() { 32 | Schema::dropIfExists('jobs'); 33 | } 34 | } 35 | -------------------------------------------------------------------------------- /database/migrations/2016_12_21_212946_create_failed_jobs_table.php: -------------------------------------------------------------------------------- 1 | increments('id'); 18 | $table->text('connection'); 19 | $table->text('queue'); 20 | $table->longText('payload'); 21 | $table->longText('exception'); 22 | $table->timestamp('failed_at')->useCurrent(); 23 | }); 24 | } 25 | 26 | /** 27 | * Reverse the migrations. 28 | * 29 | * @return void 30 | */ 31 | public function down() 32 | { 33 | Schema::dropIfExists('failed_jobs'); 34 | } 35 | } 36 | -------------------------------------------------------------------------------- /database/migrations/2016_12_24_103112_create_cache_table.php: -------------------------------------------------------------------------------- 1 | string('key')->unique(); 16 | $table->text('value'); 17 | $table->integer('expiration'); 18 | }); 19 | } 20 | 21 | /** 22 | * Reverse the migrations. 23 | * 24 | * @return void 25 | */ 26 | public function down() { 27 | Schema::dropIfExists('cache'); 28 | } 29 | } 30 | -------------------------------------------------------------------------------- /database/migrations/2016_12_27_204831_create_notifications_table.php: -------------------------------------------------------------------------------- 1 | uuid('id')->primary(); 15 | $table->string('type'); 16 | $table->morphs('notifiable'); 17 | $table->text('data'); 18 | $table->timestamp('read_at')->nullable(); 19 | $table->timestamps(); 20 | }); 21 | } 22 | 23 | /** 24 | * Reverse the migrations. 25 | * 26 | * @return void 27 | */ 28 | public function down() { 29 | Schema::dropIfExists('notifications'); 30 | } 31 | } 32 | -------------------------------------------------------------------------------- /database/seeds/.gitkeep: -------------------------------------------------------------------------------- 1 | 2 | -------------------------------------------------------------------------------- /database/seeds/AclTableSeeder.php: -------------------------------------------------------------------------------- 1 | call(UserTableSeeder::class); 13 | // $this->call(DeviceTableSeeder::class); 14 | // $this->call(MessageTableSeeder::class); 15 | } 16 | } 17 | -------------------------------------------------------------------------------- /database/seeds/DeviceTableSeeder.php: -------------------------------------------------------------------------------- 1 | create([ 16 | 'name' => 'admin', 17 | 'clientID' => 'admin', 18 | 'username' => 'admin', 19 | 'threshold' => '0.2,0.8', 20 | 'is_superuser' => 1, 21 | ]); 22 | } 23 | } 24 | -------------------------------------------------------------------------------- /database/seeds/MessageTableSeeder.php: -------------------------------------------------------------------------------- 1 | create([ 15 | 'payload' => 'on', 16 | ]); 17 | } 18 | } 19 | -------------------------------------------------------------------------------- /database/seeds/UserTableSeeder.php: -------------------------------------------------------------------------------- 1 | create([ 13 | 'name' => 'admin', 14 | 'email' => 'admin@w3hacker.com', 15 | ]); 16 | } 17 | } 18 | -------------------------------------------------------------------------------- /gulpfile.js: -------------------------------------------------------------------------------- 1 | const elixir = require('laravel-elixir'); 2 | 3 | require('laravel-elixir-vue-2'); 4 | 5 | /* 6 | |-------------------------------------------------------------------------- 7 | | Elixir Asset Management 8 | |-------------------------------------------------------------------------- 9 | | 10 | | Elixir provides a clean, fluent API for defining some basic Gulp tasks 11 | | for your Laravel application. By default, we are compiling the Sass 12 | | file for our application, as well as publishing vendor resources. 13 | | 14 | */ 15 | 16 | elixir(mix => { 17 | mix.sass('app.scss') 18 | .webpack('app.js'); 19 | }); 20 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "private": true, 3 | "scripts": { 4 | "prod": "gulp --production", 5 | "dev": "gulp watch" 6 | }, 7 | "devDependencies": { 8 | "bootstrap-sass": "^3.3.7", 9 | "gulp": "^3.9.1", 10 | "jquery": "^3.1.0", 11 | "laravel-elixir": "^6.0.0-9", 12 | "laravel-elixir-vue-2": "^0.2.0", 13 | "laravel-elixir-webpack-official": "^1.0.2", 14 | "lodash": "^4.16.2", 15 | "vue": "^2.0.1", 16 | "vue-resource": "^1.0.3" 17 | }, 18 | "dependencies": { 19 | "highcharts": "^5.0.6" 20 | } 21 | } 22 | -------------------------------------------------------------------------------- /phpunit.xml: -------------------------------------------------------------------------------- 1 | 2 | 11 | 12 | 13 | ./tests 14 | 15 | 16 | 17 | 18 | ./app 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | -------------------------------------------------------------------------------- /public/.htaccess: -------------------------------------------------------------------------------- 1 | 2 | 3 | Options -MultiViews 4 | 5 | 6 | RewriteEngine On 7 | 8 | # Redirect Trailing Slashes If Not A Folder... 9 | RewriteCond %{REQUEST_FILENAME} !-d 10 | RewriteRule ^(.*)/$ /$1 [L,R=301] 11 | 12 | # Handle Front Controller... 13 | RewriteCond %{REQUEST_FILENAME} !-d 14 | RewriteCond %{REQUEST_FILENAME} !-f 15 | RewriteRule ^ index.php [L] 16 | 17 | # Handle Authorization Header 18 | RewriteCond %{HTTP:Authorization} . 19 | RewriteRule .* - [E=HTTP_AUTHORIZATION:%{HTTP:Authorization}] 20 | 21 | -------------------------------------------------------------------------------- /public/favicon.ico: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/tennessine/laravel-project/a0743790c5e900766ff93fbf083abd2ccc9c7952/public/favicon.ico -------------------------------------------------------------------------------- /public/index.php: -------------------------------------------------------------------------------- 1 | 8 | */ 9 | 10 | /* 11 | |-------------------------------------------------------------------------- 12 | | Register The Auto Loader 13 | |-------------------------------------------------------------------------- 14 | | 15 | | Composer provides a convenient, automatically generated class loader for 16 | | our application. We just need to utilize it! We'll simply require it 17 | | into the script here so that we don't have to worry about manual 18 | | loading any of our classes later on. It feels nice to relax. 19 | | 20 | */ 21 | 22 | require __DIR__.'/../bootstrap/autoload.php'; 23 | 24 | /* 25 | |-------------------------------------------------------------------------- 26 | | Turn On The Lights 27 | |-------------------------------------------------------------------------- 28 | | 29 | | We need to illuminate PHP development, so let us turn on the lights. 30 | | This bootstraps the framework and gets it ready for use, then it 31 | | will load up this application so that we can run it and send 32 | | the responses back to the browser and delight our users. 33 | | 34 | */ 35 | 36 | $app = require_once __DIR__.'/../bootstrap/app.php'; 37 | 38 | /* 39 | |-------------------------------------------------------------------------- 40 | | Run The Application 41 | |-------------------------------------------------------------------------- 42 | | 43 | | Once we have the application, we can handle the incoming request 44 | | through the kernel, and send the associated response back to 45 | | the client's browser allowing them to enjoy the creative 46 | | and wonderful application we have prepared for them. 47 | | 48 | */ 49 | 50 | $kernel = $app->make(Illuminate\Contracts\Http\Kernel::class); 51 | 52 | $response = $kernel->handle( 53 | $request = Illuminate\Http\Request::capture() 54 | ); 55 | 56 | $response->send(); 57 | 58 | $kernel->terminate($request, $response); 59 | -------------------------------------------------------------------------------- /public/js/components/laydate-v1.1/demo.html: -------------------------------------------------------------------------------- 1 |  2 | 3 | 4 | 5 | 6 | layDate Demo 7 | 8 | 41 | 42 | 43 | 44 |
45 | 演示一: 46 | 47 |
48 |
49 |
50 |  @Name:laydate-v 日期控件说明
51 |  @Author:贤心
52 |  @Blog:http://sentsin.com
53 |  @官网:http://sentsin.com/layui/laydate
54 |  @开发版源码:http://sentsin.com/lily/lib/laydate/laydate.dev.js
55 | 
56 | 【注意事项】
57 | 一、请千万勿移动laydate中的目录结构,它们具有完整的依赖体系。使用时,只需引入laydate/laydate.js即可。
58 | 二、如果您的网站的js采用合并或模块加载,您需要打开laydate.js,修改path。
59 | 三、laydate遵循LGPL开源协议,永不收费!
60 | 四、版权最终解释权:贤心。
61 | 
演示二: 62 | 63 |
64 |
65 |

现在,您已经看到了layDate的第一个版本了,路漫漫其修远兮,不管您的网站是否存有别的日期控件,但我相信总有一日您会对layDate情有独钟。

66 | 使用文档 67 | 皮肤库 68 | 更新日志 69 | 有问必答 70 |
71 | 83 | 84 | 85 | 86 | -------------------------------------------------------------------------------- /public/js/components/laydate-v1.1/laydate/need/laydate.css: -------------------------------------------------------------------------------- 1 | /** 2 | 3 | @Name: laydate 核心样式 4 | @Author:贤心 5 | @Site:http://sentsin.com/layui/laydate 6 | 7 | **/ 8 | 9 | html{_background-image:url(about:blank); _background-attachment:fixed;} 10 | .laydate_body .laydate_box, .laydate_body .laydate_box *{margin:0; padding:0;} 11 | .laydate-icon, 12 | .laydate-icon-default, 13 | .laydate-icon-danlan, 14 | .laydate-icon-dahong, 15 | .laydate-icon-molv{height:22px; line-height:22px; padding-right:20px; border:1px solid #C6C6C6; background-repeat:no-repeat; background-position:right center; background-color:#fff; outline:0;} 16 | .laydate-icon-default{ background-image:url(../skins/default/icon.png)} 17 | .laydate-icon-danlan{border:1px solid #B1D2EC; background-image:url(../skins/danlan/icon.png)} 18 | .laydate-icon-dahong{background-image:url(../skins/dahong/icon.png)} 19 | .laydate-icon-molv{background-image:url(../skins/molv/icon.png)} 20 | .laydate_body .laydate_box{width:240px; font:12px '\5B8B\4F53'; z-index:99999999; *margin:-2px 0 0 -2px; *overflow:hidden; _margin:0; _position:absolute!important; background-color:#fff;} 21 | .laydate_body .laydate_box li{list-style:none;} 22 | .laydate_body .laydate_box .laydate_void{cursor:text!important;} 23 | .laydate_body .laydate_box a, .laydate_body .laydate_box a:hover{text-decoration:none; blr:expression(this.onFocus=this.blur()); cursor:pointer;} 24 | .laydate_body .laydate_box a:hover{text-decoration:none;} 25 | .laydate_body .laydate_box cite, .laydate_body .laydate_box label{position:absolute; width:0; height:0; border-width:5px; border-style:dashed; border-color:transparent; overflow:hidden; cursor:pointer;} 26 | .laydate_body .laydate_box .laydate_yms, .laydate_body .laydate_box .laydate_time{display:none;} 27 | .laydate_body .laydate_box .laydate_show{display:block;} 28 | .laydate_body .laydate_box input{outline:0; font-size:14px; background-color:#fff;} 29 | .laydate_body .laydate_top{position:relative; height:26px; padding:5px; *width:100%; z-index:99;} 30 | .laydate_body .laydate_ym{position:relative; float:left; height:24px; cursor:pointer;} 31 | .laydate_body .laydate_ym input{float:left; height:24px; line-height:24px; text-align:center; border:none; cursor:pointer;} 32 | .laydate_body .laydate_ym .laydate_yms{position:absolute; left: -1px; top: 24px; height:181px;} 33 | .laydate_body .laydate_y{width:121px; margin-right:6px;} 34 | .laydate_body .laydate_y input{width:64px; margin-right:15px;} 35 | .laydate_body .laydate_y .laydate_yms{width:121px; text-align:center;} 36 | .laydate_body .laydate_y .laydate_yms a{position:relative; display:block; height:20px;} 37 | .laydate_body .laydate_y .laydate_yms ul{height:139px; padding:0; *overflow:hidden;} 38 | .laydate_body .laydate_y .laydate_yms ul li{float:left; width:60px; height:20px; line-height: 20px; text-overflow: ellipsis; overflow: hidden; white-space: nowrap;} 39 | .laydate_body .laydate_m{width:99px;} 40 | .laydate_body .laydate_m .laydate_yms{width:99px; padding:0;} 41 | .laydate_body .laydate_m input{width:42px; margin-right:15px;} 42 | .laydate_body .laydate_m .laydate_yms span{display:block; float:left; width:42px; margin: 5px 0 0 5px; line-height:24px; text-align:center; _display:inline;} 43 | .laydate_body .laydate_choose{display:block; float:left; position:relative; width:20px; height:24px;} 44 | .laydate_body .laydate_choose cite, .laydate_body .laydate_tab cite{left:50%; top:50%;} 45 | .laydate_body .laydate_chtop cite{margin:-7px 0 0 -5px; border-bottom-style:solid;} 46 | .laydate_body .laydate_chdown cite, .laydate_body .laydate_ym label{top:50%; margin:-2px 0 0 -5px; border-top-style:solid;} 47 | .laydate_body .laydate_chprev cite{margin:-5px 0 0 -7px;} 48 | .laydate_body .laydate_chnext cite{margin:-5px 0 0 -2px;} 49 | .laydate_body .laydate_ym label{right:28px;} 50 | .laydate_body .laydate_table{ width:230px; margin:0 5px; border-collapse:collapse; border-spacing:0px; } 51 | .laydate_body .laydate_table td{width:31px; height:19px; line-height:19px; text-align: center; cursor:pointer; font-size: 12px;} 52 | .laydate_body .laydate_table thead{height:22px; line-height:22px;} 53 | .laydate_body .laydate_table thead th{font-weight:400; font-size:12px; text-align:center;} 54 | .laydate_body .laydate_bottom{position:relative; height:22px; line-height:20px; padding:5px; font-size:12px;} 55 | .laydate_body .laydate_bottom #laydate_hms{position: relative; z-index: 1; float:left; } 56 | .laydate_body .laydate_time{ position:absolute; left:5px; bottom: 26px; width:129px; height:125px; *overflow:hidden;} 57 | .laydate_body .laydate_time .laydate_hmsno{ padding:5px 0 0 5px;} 58 | .laydate_body .laydate_time .laydate_hmsno span{display:block; float:left; width:24px; height:19px; line-height:19px; text-align:center; cursor:pointer; *margin-bottom:-5px;} 59 | .laydate_body .laydate_time1{width:228px; height:154px;} 60 | .laydate_body .laydate_time1 .laydate_hmsno{padding: 6px 0 0 8px;} 61 | .laydate_body .laydate_time1 .laydate_hmsno span{width:21px; height:20px; line-height:20px;} 62 | .laydate_body .laydate_msg{left:49px; bottom:67px; width:141px; height:auto; overflow: hidden;} 63 | .laydate_body .laydate_msg p{padding:5px 10px;} 64 | .laydate_body .laydate_bottom li{float:left; height:20px; line-height:20px; border-right:none; font-weight:900;} 65 | .laydate_body .laydate_bottom .laydate_sj{width:33px; text-align:center; font-weight:400;} 66 | .laydate_body .laydate_bottom input{float:left; width:21px; height:20px; line-height:20px; border:none; text-align:center; cursor:pointer; font-size:12px; font-weight:400;} 67 | .laydate_body .laydate_bottom .laydte_hsmtex{height:20px; line-height:20px; text-align:center;} 68 | .laydate_body .laydate_bottom .laydte_hsmtex span{position:absolute; width:20px; top:0; right:0px; cursor:pointer;} 69 | .laydate_body .laydate_bottom .laydte_hsmtex span:hover{font-size:14px;} 70 | .laydate_body .laydate_bottom .laydate_btn{position:absolute; right:5px; top:5px;} 71 | .laydate_body .laydate_bottom .laydate_btn a{float:left; height:20px; padding:0 6px; _padding:0 5px;} 72 | .laydate_body .laydate_bottom .laydate_v{position:absolute; left:10px; top:6px; font-family:Courier; z-index:0;} 73 | 74 | -------------------------------------------------------------------------------- /public/js/components/laydate-v1.1/laydate/skins/dahong/icon.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/tennessine/laravel-project/a0743790c5e900766ff93fbf083abd2ccc9c7952/public/js/components/laydate-v1.1/laydate/skins/dahong/icon.png -------------------------------------------------------------------------------- /public/js/components/laydate-v1.1/laydate/skins/dahong/laydate.css: -------------------------------------------------------------------------------- 1 | /** 2 | 3 | @Name: laydate皮肤:大红 4 | @Author:贤心 5 | @Site:http://sentsin.com/layui/laydate 6 | 7 | **/ 8 | 9 | .laydate-icon{border:1px solid #ccc; background-image:url(icon.png)} 10 | 11 | .laydate_body .laydate_bottom #laydate_hms, 12 | .laydate_body .laydate_time{border:1px solid #ccc;} 13 | 14 | .laydate_body .laydate_box, 15 | .laydate_body .laydate_time{box-shadow: 2px 2px 5px rgba(0,0,0,.1);} 16 | 17 | .laydate_body .laydate_box{border-top:none; border-bottom:none; background-color:#fff; color:#333;} 18 | .laydate_body .laydate_box input{background:none!important; color:#fff;} 19 | .laydate_body .laydate_box .laydate_void{color:#ccc!important;} 20 | .laydate_body .laydate_box a, .laydate_body .laydate_box a:hover{color:#333;} 21 | .laydate_body .laydate_box a:hover{color:#666;} 22 | .laydate_body .laydate_click{background-color:#F32043!important; color:#fff!important;} 23 | .laydate_body .laydate_top{border-top:1px solid #D91600; background-color:#D91600} 24 | .laydate_body .laydate_ym{border:1px solid #D91600; background-color:#D91600;} 25 | .laydate_body .laydate_ym .laydate_yms{border:1px solid #D91600; background-color:#D91600; color:#fff;} 26 | .laydate_body .laydate_y .laydate_yms a{border-bottom:1px solid #D91600;} 27 | .laydate_body .laydate_y .laydate_yms .laydate_chdown{border-top:1px solid #D91600; border-bottom:none;} 28 | .laydate_body .laydate_choose{border-left:1px solid #D91600;} 29 | .laydate_body .laydate_chprev{border-left:none; border-right:1px solid #D91600;} 30 | .laydate_body .laydate_choose:hover, 31 | .laydate_body .laydate_y .laydate_yms a:hover{background-color:#F54766;} 32 | .laydate_body .laydate_chtop cite{border-bottom-color:#fff;} 33 | .laydate_body .laydate_chdown cite, .laydate_body .laydate_ym label{border-top-color:#fff;} 34 | .laydate_body .laydate_chprev cite{border-right-style:solid; border-right-color:#fff;} 35 | .laydate_body .laydate_chnext cite{border-left-style:solid; border-left-color:#fff;} 36 | .laydate_body .laydate_table{width: 240px!important; margin: 0!important; border:1px solid #ccc; border-top:none; border-bottom:none;} 37 | .laydate_body .laydate_table td{border:none; height:21px!important; line-height:21px!important; background-color:#fff; color:#333;} 38 | .laydate_body .laydate_table .laydate_nothis{color:#999;} 39 | .laydate_body .laydate_table thead{border-bottom:1px solid #ccc; height:21px!important; line-height:21px!important;} 40 | .laydate_body .laydate_table thead th{} 41 | .laydate_body .laydate_bottom{border:1px solid #ccc; border-top:none;} 42 | .laydate_body .laydate_bottom #laydate_hms{background-color:#fff;} 43 | .laydate_body .laydate_time{background-color:#fff;} 44 | .laydate_body .laydate_time1{width: 226px!important; height: 152px!important;} 45 | .laydate_body .laydate_bottom .laydate_sj{width:31px!important; border-right:1px solid #ccc; background-color:#fff;} 46 | .laydate_body .laydate_bottom input{background-color:#fff; color:#333;} 47 | .laydate_body .laydate_bottom .laydte_hsmtex{border-bottom:1px solid #ccc;} 48 | .laydate_body .laydate_bottom .laydate_btn{border-right:1px solid #ccc;} 49 | .laydate_body .laydate_bottom .laydate_v{color:#999} 50 | .laydate_body .laydate_bottom .laydate_btn a{border: 1px solid #ccc; border-right:none; background-color:#fff;} 51 | .laydate_body .laydate_bottom .laydate_btn a:hover{background-color:#F6F6F6; color:#333;} 52 | 53 | .laydate_body .laydate_m .laydate_yms span:hover, 54 | .laydate_body .laydate_time .laydate_hmsno span:hover, 55 | .laydate_body .laydate_y .laydate_yms ul li:hover, 56 | .laydate_body .laydate_table td:hover{background-color:#F54766; color:#fff;} 57 | 58 | 59 | -------------------------------------------------------------------------------- /public/js/components/laydate-v1.1/laydate/skins/default/icon.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/tennessine/laravel-project/a0743790c5e900766ff93fbf083abd2ccc9c7952/public/js/components/laydate-v1.1/laydate/skins/default/icon.png -------------------------------------------------------------------------------- /public/js/components/laydate-v1.1/laydate/skins/default/laydate.css: -------------------------------------------------------------------------------- 1 | /** 2 | 3 | @Name: laydate皮肤:默认 4 | @Author:贤心 5 | @Site:http://sentsin.com/layui/laydate 6 | 7 | **/ 8 | 9 | .laydate-icon{border:1px solid #C6C6C6; background-image:url(icon.png)} 10 | 11 | .laydate_body .laydate_box, 12 | .laydate_body .laydate_ym, 13 | .laydate_body .laydate_ym .laydate_yms, 14 | .laydate_body .laydate_table, 15 | .laydate_body .laydate_table td, 16 | .laydate_body .laydate_bottom #laydate_hms, 17 | .laydate_body .laydate_time, 18 | .laydate_body .laydate_bottom .laydate_btn a{border:1px solid #ccc;} 19 | 20 | .laydate_body .laydate_y .laydate_yms a, 21 | .laydate_body .laydate_choose, 22 | .laydate_body .laydate_table thead, 23 | .laydate_body .laydate_bottom .laydte_hsmtex{background-color:#F6F6F6;} 24 | 25 | .laydate_body .laydate_box, 26 | .laydate_body .laydate_ym .laydate_yms, 27 | .laydate_body .laydate_time{box-shadow: 2px 2px 5px rgba(0,0,0,.1);} 28 | 29 | .laydate_body .laydate_box{border-top:none; border-bottom:none; background-color:#fff; color:#333;} 30 | .laydate_body .laydate_box input{color:#333;} 31 | .laydate_body .laydate_box .laydate_void{color:#ccc!important; /*text-decoration:line-through;*/} 32 | .laydate_body .laydate_box .laydate_void:hover{background-color:#fff!important} 33 | .laydate_body .laydate_box a, .laydate_body .laydate_box a:hover{color:#333;} 34 | .laydate_body .laydate_box a:hover{color:#666;} 35 | .laydate_body .laydate_click{background-color:#eee!important;} 36 | .laydate_body .laydate_top{border-top:1px solid #C6C6C6;} 37 | .laydate_body .laydate_ym .laydate_yms{border:1px solid #C6C6C6; background-color:#fff;} 38 | .laydate_body .laydate_y .laydate_yms a{border-bottom:1px solid #C6C6C6;} 39 | .laydate_body .laydate_y .laydate_yms .laydate_chdown{border-top:1px solid #C6C6C6; border-bottom:none;} 40 | .laydate_body .laydate_choose{border-left:1px solid #C6C6C6;} 41 | .laydate_body .laydate_chprev{border-left:none; border-right:1px solid #C6C6C6;} 42 | .laydate_body .laydate_choose:hover, 43 | .laydate_body .laydate_y .laydate_yms a:hover{background-color:#fff;} 44 | .laydate_body .laydate_chtop cite{border-bottom-color:#666;} 45 | .laydate_body .laydate_chdown cite, .laydate_body .laydate_ym label{border-top-color:#666;} 46 | .laydate_body .laydate_chprev cite{border-right-style:solid; border-right-color:#666;} 47 | .laydate_body .laydate_chnext cite{border-left-style:solid; border-left-color:#666;} 48 | .laydate_body .laydate_table td{border:none; height:21px!important; line-height:21px!important; background-color:#fff;} 49 | .laydate_body .laydate_table .laydate_nothis{color:#999;} 50 | .laydate_body .laydate_table thead{height:21px!important; line-height:21px!important;} 51 | .laydate_body .laydate_table thead th{border-bottom:1px solid #ccc;} 52 | .laydate_body .laydate_bottom{border-bottom:1px solid #C6C6C6;} 53 | .laydate_body .laydate_bottom #laydate_hms{background-color:#fff;} 54 | .laydate_body .laydate_time{background-color:#fff;} 55 | .laydate_body .laydate_bottom .laydate_sj{border-right:1px solid #C6C6C6; background-color:#F6F6F6;} 56 | .laydate_body .laydate_bottom input{background-color:#fff;} 57 | .laydate_body .laydate_bottom .laydte_hsmtex{border-bottom:1px solid #C6C6C6;} 58 | .laydate_body .laydate_bottom .laydate_btn{border-right:1px solid #C6C6C6;} 59 | .laydate_body .laydate_bottom .laydate_v{color:#999} 60 | .laydate_body .laydate_bottom .laydate_btn a{border-right:none; background-color:#F6F6F6;} 61 | .laydate_body .laydate_bottom .laydate_btn a:hover{color:#000; background-color:#fff;} 62 | 63 | .laydate_body .laydate_m .laydate_yms span:hover, 64 | .laydate_body .laydate_y .laydate_yms ul li:hover, 65 | .laydate_body .laydate_table td:hover, 66 | .laydate_body .laydate_time .laydate_hmsno span:hover{background-color:#F3F3F3} 67 | 68 | 69 | -------------------------------------------------------------------------------- /public/js/components/laydate-v1.1/laydate/skins/molv/icon.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/tennessine/laravel-project/a0743790c5e900766ff93fbf083abd2ccc9c7952/public/js/components/laydate-v1.1/laydate/skins/molv/icon.png -------------------------------------------------------------------------------- /public/js/components/laydate-v1.1/laydate/skins/molv/laydate.css: -------------------------------------------------------------------------------- 1 | /** 2 | 3 | @Name: laydate皮肤:墨绿 4 | @Author:贤心 5 | @Site:http://sentsin.com/layui/laydate 6 | 7 | **/ 8 | 9 | .laydate-icon{border:1px solid #ccc; background-image:url(icon.png)} 10 | 11 | .laydate_body .laydate_bottom #laydate_hms, 12 | .laydate_body .laydate_time{border:1px solid #ccc;} 13 | 14 | .laydate_body .laydate_box, 15 | .laydate_body .laydate_ym .laydate_yms, 16 | .laydate_body .laydate_time{box-shadow: 2px 2px 5px rgba(0,0,0,.1);} 17 | 18 | .laydate_body .laydate_box{border-top:none; border-bottom:none; background-color:#fff; color:#00625A;} 19 | .laydate_body .laydate_box input{background:none!important; color:#fff;} 20 | .laydate_body .laydate_box .laydate_void{color:#00E8D7!important;} 21 | .laydate_body .laydate_box a, .laydate_body .laydate_box a:hover{color:#00625A;} 22 | .laydate_body .laydate_box a:hover{color:#666;} 23 | .laydate_body .laydate_click{background-color:#009F95!important; color:#fff!important;} 24 | .laydate_body .laydate_top{border-top:1px solid #009F95; background-color:#009F95} 25 | .laydate_body .laydate_ym{border:1px solid #009F95; background-color:#009F95;} 26 | .laydate_body .laydate_ym .laydate_yms{border:1px solid #009F95; background-color:#009F95; color:#fff;} 27 | .laydate_body .laydate_y .laydate_yms a{border-bottom:1px solid #009F95;} 28 | .laydate_body .laydate_y .laydate_yms .laydate_chdown{border-top:1px solid #009F95; border-bottom:none;} 29 | .laydate_body .laydate_choose{border-left:1px solid #009F95;} 30 | .laydate_body .laydate_chprev{border-left:none; border-right:1px solid #009F95;} 31 | .laydate_body .laydate_choose:hover, 32 | .laydate_body .laydate_y .laydate_yms a:hover{background-color:#00C1B3;} 33 | .laydate_body .laydate_chtop cite{border-bottom-color:#fff;} 34 | .laydate_body .laydate_chdown cite, .laydate_body .laydate_ym label{border-top-color:#fff;} 35 | .laydate_body .laydate_chprev cite{border-right-style:solid; border-right-color:#fff;} 36 | .laydate_body .laydate_chnext cite{border-left-style:solid; border-left-color:#fff;} 37 | .laydate_body .laydate_table{width: 240px!important; margin: 0!important; border:1px solid #ccc; border-top:none; border-bottom:none;} 38 | .laydate_body .laydate_table td{border:none; height:21px!important; line-height:21px!important; background-color:#fff; color:#00625A;} 39 | .laydate_body .laydate_table .laydate_nothis{color:#999;} 40 | .laydate_body .laydate_table thead{border-bottom:1px solid #ccc; height:21px!important; line-height:21px!important;} 41 | .laydate_body .laydate_table thead th{} 42 | .laydate_body .laydate_bottom{border:1px solid #ccc; border-top:none;} 43 | .laydate_body .laydate_bottom #laydate_hms{background-color:#fff;} 44 | .laydate_body .laydate_time{background-color:#fff;} 45 | .laydate_body .laydate_time1{width: 226px!important; height: 152px!important;} 46 | .laydate_body .laydate_bottom .laydate_sj{width:31px!important; border-right:1px solid #ccc; background-color:#fff;} 47 | .laydate_body .laydate_bottom input{background-color:#fff; color:#00625A;} 48 | .laydate_body .laydate_bottom .laydte_hsmtex{border-bottom:1px solid #ccc;} 49 | .laydate_body .laydate_bottom .laydate_btn{border-right:1px solid #ccc;} 50 | .laydate_body .laydate_bottom .laydate_v{color:#999} 51 | .laydate_body .laydate_bottom .laydate_btn a{border: 1px solid #ccc; border-right:none; background-color:#fff;} 52 | .laydate_body .laydate_bottom .laydate_btn a:hover{background-color:#F6F6F6; color:#00625A;} 53 | 54 | .laydate_body .laydate_m .laydate_yms span:hover, 55 | .laydate_body .laydate_time .laydate_hmsno span:hover, 56 | .laydate_body .laydate_y .laydate_yms ul li:hover, 57 | .laydate_body .laydate_table td:hover{background-color:#00C1B3; color:#fff;} 58 | 59 | 60 | -------------------------------------------------------------------------------- /public/js/components/layer-v3.0.1/demo.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | layer-更懂你的web弹窗解决方案 8 | 9 | 10 | 11 | 23 | 24 | 25 |
26 |
27 |  @Name:layer-v 弹层组件说明
28 |  @Author:贤心
29 |  @Site:http://layer.layui.com/
30 | 
31 | 
32 | 【注意事项】
33 | 一、使用时,请把文件夹layer整个放置在您站点的任何一个目录,只需引入layer.js即可,除jQuery外,其它文件无需再引入。
34 | 二、如果您的js引入是通过合并处理或者您不想采用layer自动获取的绝对路径,您可以通过layer.config()来配置(详见官网API页)
35 | 三、jquery需1.8+
36 | 四、更多使用说明与演示,请参见layer官网。
37 | 五、使用时请务必保留来源,请勿用于违反我国法律的web平台。
38 | 六、layer遵循MIT开源协议,将永久性提供无偿服务。
39 | 
40 |
41 | 42 |
43 | 更多示例 44 | 使用文档 45 | 交流反馈 46 | 关于 47 |
48 | 49 | 77 | 78 | -------------------------------------------------------------------------------- /public/js/components/layer-v3.0.1/layer/mobile/layer.js: -------------------------------------------------------------------------------- 1 | /*! layer mobile-v2.0.0 Web弹层组件 MIT License http://layer.layui.com/mobile By 贤心 */ 2 | ;!function(e){"use strict";var t=document,n="querySelectorAll",i="getElementsByClassName",a=function(e){return t[n](e)},s={type:0,shade:!0,shadeClose:!0,fixed:!0,anim:"scale"},l={extend:function(e){var t=JSON.parse(JSON.stringify(s));for(var n in e)t[n]=e[n];return t},timer:{},end:{}};l.touch=function(e,t){e.addEventListener("click",function(e){t.call(this,e)},!1)};var r=0,o=["layui-m-layer"],c=function(e){var t=this;t.config=l.extend(e),t.view()};c.prototype.view=function(){var e=this,n=e.config,s=t.createElement("div");e.id=s.id=o[0]+r,s.setAttribute("class",o[0]+" "+o[0]+(n.type||0)),s.setAttribute("index",r);var l=function(){var e="object"==typeof n.title;return n.title?'

'+(e?n.title[0]:n.title)+"

":""}(),c=function(){"string"==typeof n.btn&&(n.btn=[n.btn]);var e,t=(n.btn||[]).length;return 0!==t&&n.btn?(e=''+n.btn[0]+"",2===t&&(e=''+n.btn[1]+""+e),'
'+e+"
"):""}();if(n.fixed||(n.top=n.hasOwnProperty("top")?n.top:100,n.style=n.style||"",n.style+=" top:"+(t.body.scrollTop+n.top)+"px"),2===n.type&&(n.content='

'+(n.content||"")+"

"),n.skin&&(n.anim="up"),"msg"===n.skin&&(n.shade=!1),s.innerHTML=(n.shade?"
':"")+'
"+l+'
'+n.content+"
"+c+"
",!n.type||2===n.type){var d=t[i](o[0]+n.type),y=d.length;y>=1&&layer.close(d[0].getAttribute("index"))}document.body.appendChild(s);var u=e.elem=a("#"+e.id)[0];n.success&&n.success(u),e.index=r++,e.action(n,u)},c.prototype.action=function(e,t){var n=this;e.time&&(l.timer[n.index]=setTimeout(function(){layer.close(n.index)},1e3*e.time));var a=function(){var t=this.getAttribute("type");0==t?(e.no&&e.no(),layer.close(n.index)):e.yes?e.yes(n.index):layer.close(n.index)};if(e.btn)for(var s=t[i]("layui-m-layerbtn")[0].children,r=s.length,o=0;odiv{line-height:22px;padding-top:7px;margin-bottom:20px;font-size:14px}.layui-m-layerbtn{display:box;display:-moz-box;display:-webkit-box;width:100%;height:50px;line-height:50px;font-size:0;border-top:1px solid #D0D0D0;background-color:#F2F2F2}.layui-m-layerbtn span{display:block;-moz-box-flex:1;box-flex:1;-webkit-box-flex:1;font-size:14px;cursor:pointer}.layui-m-layerbtn span[yes]{color:#40AFFE}.layui-m-layerbtn span[no]{border-right:1px solid #D0D0D0;border-radius:0 0 0 5px}.layui-m-layerbtn span:active{background-color:#F6F6F6}.layui-m-layerend{position:absolute;right:7px;top:10px;width:30px;height:30px;border:0;font-weight:400;background:0 0;cursor:pointer;-webkit-appearance:none;font-size:30px}.layui-m-layerend::after,.layui-m-layerend::before{position:absolute;left:5px;top:15px;content:'';width:18px;height:1px;background-color:#999;transform:rotate(45deg);-webkit-transform:rotate(45deg);border-radius:3px}.layui-m-layerend::after{transform:rotate(-45deg);-webkit-transform:rotate(-45deg)}body .layui-m-layer .layui-m-layer-footer{position:fixed;width:95%;max-width:100%;margin:0 auto;left:0;right:0;bottom:10px;background:0 0}.layui-m-layer-footer .layui-m-layercont{padding:20px;border-radius:5px 5px 0 0;background-color:rgba(255,255,255,.8)}.layui-m-layer-footer .layui-m-layerbtn{display:block;height:auto;background:0 0;border-top:none}.layui-m-layer-footer .layui-m-layerbtn span{background-color:rgba(255,255,255,.8)}.layui-m-layer-footer .layui-m-layerbtn span[no]{color:#FD482C;border-top:1px solid #c2c2c2;border-radius:0 0 5px 5px}.layui-m-layer-footer .layui-m-layerbtn span[yes]{margin-top:10px;border-radius:5px}body .layui-m-layer .layui-m-layer-msg{width:auto;max-width:90%;margin:0 auto;bottom:-150px;background-color:rgba(0,0,0,.7);color:#fff}.layui-m-layer-msg .layui-m-layercont{padding:10px 20px} -------------------------------------------------------------------------------- /public/js/components/layer-v3.0.1/layer/skin/default/icon-ext.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/tennessine/laravel-project/a0743790c5e900766ff93fbf083abd2ccc9c7952/public/js/components/layer-v3.0.1/layer/skin/default/icon-ext.png -------------------------------------------------------------------------------- /public/js/components/layer-v3.0.1/layer/skin/default/icon.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/tennessine/laravel-project/a0743790c5e900766ff93fbf083abd2ccc9c7952/public/js/components/layer-v3.0.1/layer/skin/default/icon.png -------------------------------------------------------------------------------- /public/js/components/layer-v3.0.1/layer/skin/default/loading-0.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/tennessine/laravel-project/a0743790c5e900766ff93fbf083abd2ccc9c7952/public/js/components/layer-v3.0.1/layer/skin/default/loading-0.gif -------------------------------------------------------------------------------- /public/js/components/layer-v3.0.1/layer/skin/default/loading-1.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/tennessine/laravel-project/a0743790c5e900766ff93fbf083abd2ccc9c7952/public/js/components/layer-v3.0.1/layer/skin/default/loading-1.gif -------------------------------------------------------------------------------- /public/js/components/layer-v3.0.1/layer/skin/default/loading-2.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/tennessine/laravel-project/a0743790c5e900766ff93fbf083abd2ccc9c7952/public/js/components/layer-v3.0.1/layer/skin/default/loading-2.gif -------------------------------------------------------------------------------- /public/robots.txt: -------------------------------------------------------------------------------- 1 | User-agent: * 2 | Disallow: 3 | -------------------------------------------------------------------------------- /public/web.config: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | -------------------------------------------------------------------------------- /readme.md: -------------------------------------------------------------------------------- 1 | 本项目用到了以下软件 2 | 3 | - emqtt 开发了设备上下线维护、消息保存功能插件 用的erlang语言 4 | - 使用websocket连接emqtt实现在后台发送指令控制远程设备 5 | - 使用highchart做图表, 输出设备统计信息 6 | - bootstrap、jQuery -------------------------------------------------------------------------------- /resources/assets/js/app.js: -------------------------------------------------------------------------------- 1 | /** 2 | * First we will load all of this project's JavaScript dependencies which 3 | * include Vue and Vue Resource. This gives a great starting point for 4 | * building robust, powerful web applications using Vue and Laravel. 5 | */ 6 | 7 | require('./bootstrap'); 8 | 9 | /** 10 | * Next, we will create a fresh Vue application instance and attach it to 11 | * the body of the page. From here, you may begin adding components to 12 | * the application, or feel free to tweak this setup for your needs. 13 | */ 14 | -------------------------------------------------------------------------------- /resources/assets/js/bootstrap.js: -------------------------------------------------------------------------------- 1 | window._ = require('lodash'); 2 | 3 | /** 4 | * We'll load jQuery and the Bootstrap jQuery plugin which provides support 5 | * for JavaScript based Bootstrap features such as modals and tabs. This 6 | * code may be modified to fit the specific needs of your application. 7 | */ 8 | 9 | window.$ = window.jQuery = require('jquery'); 10 | require('bootstrap-sass'); 11 | // require('bootstrap'); 12 | 13 | window.Highcharts = require('highcharts'); 14 | 15 | /** 16 | * Vue is a modern JavaScript library for building interactive web interfaces 17 | * using reactive data binding and reusable components. Vue's API is clean 18 | * and simple, leaving you to focus on building your next great project. 19 | */ 20 | 21 | window.Vue = require('vue'); 22 | require('vue-resource'); 23 | 24 | /** 25 | * We'll register a HTTP interceptor to attach the "CSRF" header to each of 26 | * the outgoing requests issued by this application. The CSRF middleware 27 | * included with Laravel will automatically verify the header's value. 28 | */ 29 | 30 | Vue.http.interceptors.push((request, next) => { 31 | request.headers.set('X-CSRF-TOKEN', Laravel.csrfToken); 32 | 33 | next(); 34 | }); 35 | 36 | /** 37 | * Echo exposes an expressive API for subscribing to channels and listening 38 | * for events that are broadcast by Laravel. Echo and event broadcasting 39 | * allows your team to easily build robust real-time web applications. 40 | */ 41 | 42 | // import Echo from "laravel-echo" 43 | 44 | // window.Echo = new Echo({ 45 | // broadcaster: 'pusher', 46 | // key: 'your-pusher-key' 47 | // }); 48 | -------------------------------------------------------------------------------- /resources/assets/js/components/Example.vue: -------------------------------------------------------------------------------- 1 | 16 | 17 | 24 | -------------------------------------------------------------------------------- /resources/assets/sass/_variables.scss: -------------------------------------------------------------------------------- 1 | 2 | // Body 3 | $body-bg: #f5f8fa; 4 | 5 | // Borders 6 | $laravel-border-color: darken($body-bg, 10%); 7 | $list-group-border: $laravel-border-color; 8 | $navbar-default-border: $laravel-border-color; 9 | $panel-default-border: $laravel-border-color; 10 | $panel-inner-border: $laravel-border-color; 11 | 12 | // Brands 13 | $brand-primary: #3097D1; 14 | $brand-info: #8eb4cb; 15 | $brand-success: #2ab27b; 16 | $brand-warning: #cbb956; 17 | $brand-danger: #bf5329; 18 | 19 | // Typography 20 | $font-family-sans-serif: "Raleway", sans-serif; 21 | $font-size-base: 14px; 22 | $line-height-base: 1.6; 23 | $text-color: #636b6f; 24 | 25 | // Navbar 26 | $navbar-default-bg: #fff; 27 | 28 | // Buttons 29 | $btn-default-color: $text-color; 30 | 31 | // Inputs 32 | $input-border: lighten($text-color, 40%); 33 | $input-border-focus: lighten($brand-primary, 25%); 34 | $input-color-placeholder: lighten($text-color, 30%); 35 | 36 | // Panels 37 | $panel-default-heading-bg: #fff; 38 | -------------------------------------------------------------------------------- /resources/assets/sass/app.scss: -------------------------------------------------------------------------------- 1 | 2 | // Fonts 3 | @import url(https://fonts.googleapis.com/css?family=Raleway:300,400,600); 4 | 5 | // Variables 6 | @import "variables"; 7 | 8 | // Bootstrap 9 | @import "node_modules/bootstrap-sass/assets/stylesheets/bootstrap"; 10 | 11 | th, td { 12 | text-align: center !important; 13 | } 14 | 15 | .led-box { 16 | width: 25%; 17 | margin: 10px 0; 18 | float: left; 19 | margin-bottom: 1em; 20 | } 21 | 22 | .led-box p { 23 | font-size: 12px; 24 | text-align: center; 25 | margin: 1em; 26 | } 27 | 28 | .led-gray { 29 | margin: 0 auto; 30 | width: 24px; 31 | height: 24px; 32 | background-color: gray; 33 | border-radius: 50%; 34 | box-shadow: rgba(0, 0, 0, 0.2) 0 -1px 7px 1px, inset gray 0 -1px 9px, rgba(0, 0, 0, 0.5) 0 2px 12px; 35 | } 36 | 37 | .led-red { 38 | margin: 0 auto; 39 | width: 24px; 40 | height: 24px; 41 | background-color: #F00; 42 | border-radius: 50%; 43 | box-shadow: rgba(0, 0, 0, 0.2) 0 -1px 7px 1px, inset #441313 0 -1px 9px, rgba(255, 0, 0, 0.5) 0 2px 12px; 44 | } 45 | .led-red.on { 46 | -webkit-animation: blinkRed 0.5s infinite; 47 | -moz-animation: blinkRed 0.5s infinite; 48 | -ms-animation: blinkRed 0.5s infinite; 49 | -o-animation: blinkRed 0.5s infinite; 50 | animation: blinkRed 0.5s infinite; 51 | } 52 | 53 | @-webkit-keyframes blinkRed { 54 | from { background-color: #F00; } 55 | 50% { background-color: #A00; box-shadow: rgba(0, 0, 0, 0.2) 0 -1px 7px 1px, inset #441313 0 -1px 9px, rgba(255, 0, 0, 0.5) 0 2px 0;} 56 | to { background-color: #F00; } 57 | } 58 | @-moz-keyframes blinkRed { 59 | from { background-color: #F00; } 60 | 50% { background-color: #A00; box-shadow: rgba(0, 0, 0, 0.2) 0 -1px 7px 1px, inset #441313 0 -1px 9px, rgba(255, 0, 0, 0.5) 0 2px 0;} 61 | to { background-color: #F00; } 62 | } 63 | @-ms-keyframes blinkRed { 64 | from { background-color: #F00; } 65 | 50% { background-color: #A00; box-shadow: rgba(0, 0, 0, 0.2) 0 -1px 7px 1px, inset #441313 0 -1px 9px, rgba(255, 0, 0, 0.5) 0 2px 0;} 66 | to { background-color: #F00; } 67 | } 68 | @-o-keyframes blinkRed { 69 | from { background-color: #F00; } 70 | 50% { background-color: #A00; box-shadow: rgba(0, 0, 0, 0.2) 0 -1px 7px 1px, inset #441313 0 -1px 9px, rgba(255, 0, 0, 0.5) 0 2px 0;} 71 | to { background-color: #F00; } 72 | } 73 | @keyframes blinkRed { 74 | from { background-color: #F00; } 75 | 50% { background-color: #A00; box-shadow: rgba(0, 0, 0, 0.2) 0 -1px 7px 1px, inset #441313 0 -1px 9px, rgba(255, 0, 0, 0.5) 0 2px 0;} 76 | to { background-color: #F00; } 77 | } 78 | 79 | .led-yellow { 80 | margin: 0 auto; 81 | width: 24px; 82 | height: 24px; 83 | background-color: #FF0; 84 | border-radius: 50%; 85 | box-shadow: rgba(0, 0, 0, 0.2) 0 -1px 7px 1px, inset #808002 0 -1px 9px, #FF0 0 2px 12px; 86 | } 87 | 88 | .led-yellow.on { 89 | -webkit-animation: blinkYellow 1s infinite; 90 | -moz-animation: blinkYellow 1s infinite; 91 | -ms-animation: blinkYellow 1s infinite; 92 | -o-animation: blinkYellow 1s infinite; 93 | animation: blinkYellow 1s infinite; 94 | } 95 | 96 | @-webkit-keyframes blinkYellow { 97 | from { background-color: #FF0; } 98 | 50% { background-color: #AA0; box-shadow: rgba(0, 0, 0, 0.2) 0 -1px 7px 1px, inset #808002 0 -1px 9px, #FF0 0 2px 0; } 99 | to { background-color: #FF0; } 100 | } 101 | @-moz-keyframes blinkYellow { 102 | from { background-color: #FF0; } 103 | 50% { background-color: #AA0; box-shadow: rgba(0, 0, 0, 0.2) 0 -1px 7px 1px, inset #808002 0 -1px 9px, #FF0 0 2px 0; } 104 | to { background-color: #FF0; } 105 | } 106 | @-ms-keyframes blinkYellow { 107 | from { background-color: #FF0; } 108 | 50% { background-color: #AA0; box-shadow: rgba(0, 0, 0, 0.2) 0 -1px 7px 1px, inset #808002 0 -1px 9px, #FF0 0 2px 0; } 109 | to { background-color: #FF0; } 110 | } 111 | @-o-keyframes blinkYellow { 112 | from { background-color: #FF0; } 113 | 50% { background-color: #AA0; box-shadow: rgba(0, 0, 0, 0.2) 0 -1px 7px 1px, inset #808002 0 -1px 9px, #FF0 0 2px 0; } 114 | to { background-color: #FF0; } 115 | } 116 | @keyframes blinkYellow { 117 | from { background-color: #FF0; } 118 | 50% { background-color: #AA0; box-shadow: rgba(0, 0, 0, 0.2) 0 -1px 7px 1px, inset #808002 0 -1px 9px, #FF0 0 2px 0; } 119 | to { background-color: #FF0; } 120 | } 121 | 122 | .led-green { 123 | margin: 0 auto; 124 | width: 24px; 125 | height: 24px; 126 | background-color: #ABFF00; 127 | border-radius: 50%; 128 | box-shadow: rgba(0, 0, 0, 0.2) 0 -1px 7px 1px, inset #304701 0 -1px 9px, #89FF00 0 2px 12px; 129 | } 130 | 131 | .led-blue { 132 | margin: 0 auto; 133 | width: 24px; 134 | height: 24px; 135 | background-color: #24E0FF; 136 | border-radius: 50%; 137 | box-shadow: rgba(0, 0, 0, 0.2) 0 -1px 7px 1px, inset #006 0 -1px 9px, #3F8CFF 0 2px 14px; 138 | } 139 | -------------------------------------------------------------------------------- /resources/lang/en/auth.php: -------------------------------------------------------------------------------- 1 | 'These credentials do not match our records.', 17 | 'throttle' => 'Too many login attempts. Please try again in :seconds seconds.', 18 | 19 | ]; 20 | -------------------------------------------------------------------------------- /resources/lang/en/pagination.php: -------------------------------------------------------------------------------- 1 | '« Previous', 17 | 'next' => 'Next »', 18 | 19 | ]; 20 | -------------------------------------------------------------------------------- /resources/lang/en/passwords.php: -------------------------------------------------------------------------------- 1 | 'Passwords must be at least six characters and match the confirmation.', 17 | 'reset' => 'Your password has been reset!', 18 | 'sent' => 'We have e-mailed your password reset link!', 19 | 'token' => 'This password reset token is invalid.', 20 | 'user' => "We can't find a user with that e-mail address.", 21 | 22 | ]; 23 | -------------------------------------------------------------------------------- /resources/lang/en/validation.php: -------------------------------------------------------------------------------- 1 | 'The :attribute must be accepted.', 17 | 'active_url' => 'The :attribute is not a valid URL.', 18 | 'after' => 'The :attribute must be a date after :date.', 19 | 'alpha' => 'The :attribute may only contain letters.', 20 | 'alpha_dash' => 'The :attribute may only contain letters, numbers, and dashes.', 21 | 'alpha_num' => 'The :attribute may only contain letters and numbers.', 22 | 'array' => 'The :attribute must be an array.', 23 | 'before' => 'The :attribute must be a date before :date.', 24 | 'between' => [ 25 | 'numeric' => 'The :attribute must be between :min and :max.', 26 | 'file' => 'The :attribute must be between :min and :max kilobytes.', 27 | 'string' => 'The :attribute must be between :min and :max characters.', 28 | 'array' => 'The :attribute must have between :min and :max items.', 29 | ], 30 | 'boolean' => 'The :attribute field must be true or false.', 31 | 'confirmed' => 'The :attribute confirmation does not match.', 32 | 'date' => 'The :attribute is not a valid date.', 33 | 'date_format' => 'The :attribute does not match the format :format.', 34 | 'different' => 'The :attribute and :other must be different.', 35 | 'digits' => 'The :attribute must be :digits digits.', 36 | 'digits_between' => 'The :attribute must be between :min and :max digits.', 37 | 'dimensions' => 'The :attribute has invalid image dimensions.', 38 | 'distinct' => 'The :attribute field has a duplicate value.', 39 | 'email' => 'The :attribute must be a valid email address.', 40 | 'exists' => 'The selected :attribute is invalid.', 41 | 'file' => 'The :attribute must be a file.', 42 | 'filled' => 'The :attribute field is required.', 43 | 'image' => 'The :attribute must be an image.', 44 | 'in' => 'The selected :attribute is invalid.', 45 | 'in_array' => 'The :attribute field does not exist in :other.', 46 | 'integer' => 'The :attribute must be an integer.', 47 | 'ip' => 'The :attribute must be a valid IP address.', 48 | 'json' => 'The :attribute must be a valid JSON string.', 49 | 'max' => [ 50 | 'numeric' => 'The :attribute may not be greater than :max.', 51 | 'file' => 'The :attribute may not be greater than :max kilobytes.', 52 | 'string' => 'The :attribute may not be greater than :max characters.', 53 | 'array' => 'The :attribute may not have more than :max items.', 54 | ], 55 | 'mimes' => 'The :attribute must be a file of type: :values.', 56 | 'mimetypes' => 'The :attribute must be a file of type: :values.', 57 | 'min' => [ 58 | 'numeric' => 'The :attribute must be at least :min.', 59 | 'file' => 'The :attribute must be at least :min kilobytes.', 60 | 'string' => 'The :attribute must be at least :min characters.', 61 | 'array' => 'The :attribute must have at least :min items.', 62 | ], 63 | 'not_in' => 'The selected :attribute is invalid.', 64 | 'numeric' => 'The :attribute must be a number.', 65 | 'present' => 'The :attribute field must be present.', 66 | 'regex' => 'The :attribute format is invalid.', 67 | 'required' => 'The :attribute field is required.', 68 | 'required_if' => 'The :attribute field is required when :other is :value.', 69 | 'required_unless' => 'The :attribute field is required unless :other is in :values.', 70 | 'required_with' => 'The :attribute field is required when :values is present.', 71 | 'required_with_all' => 'The :attribute field is required when :values is present.', 72 | 'required_without' => 'The :attribute field is required when :values is not present.', 73 | 'required_without_all' => 'The :attribute field is required when none of :values are present.', 74 | 'same' => 'The :attribute and :other must match.', 75 | 'size' => [ 76 | 'numeric' => 'The :attribute must be :size.', 77 | 'file' => 'The :attribute must be :size kilobytes.', 78 | 'string' => 'The :attribute must be :size characters.', 79 | 'array' => 'The :attribute must contain :size items.', 80 | ], 81 | 'string' => 'The :attribute must be a string.', 82 | 'timezone' => 'The :attribute must be a valid zone.', 83 | 'unique' => 'The :attribute has already been taken.', 84 | 'uploaded' => 'The :attribute failed to upload.', 85 | 'url' => 'The :attribute format is invalid.', 86 | 87 | /* 88 | |-------------------------------------------------------------------------- 89 | | Custom Validation Language Lines 90 | |-------------------------------------------------------------------------- 91 | | 92 | | Here you may specify custom validation messages for attributes using the 93 | | convention "attribute.rule" to name the lines. This makes it quick to 94 | | specify a specific custom language line for a given attribute rule. 95 | | 96 | */ 97 | 98 | 'custom' => [ 99 | 'attribute-name' => [ 100 | 'rule-name' => 'custom-message', 101 | ], 102 | ], 103 | 104 | /* 105 | |-------------------------------------------------------------------------- 106 | | Custom Validation Attributes 107 | |-------------------------------------------------------------------------- 108 | | 109 | | The following language lines are used to swap attribute place-holders 110 | | with something more reader friendly such as E-Mail Address instead 111 | | of "email". This simply helps us make messages a little cleaner. 112 | | 113 | */ 114 | 115 | 'attributes' => [], 116 | 117 | ]; 118 | -------------------------------------------------------------------------------- /resources/lang/zh/validation.php: -------------------------------------------------------------------------------- 1 | '不合法', 5 | 'bar' => '不合法', 6 | 'custom' => [ 7 | 'email' => [ 8 | 'required' => '邮箱必须填写', 9 | ], 10 | ], 11 | 'attributes' => [ 12 | 'email' => '邮箱', 13 | ], 14 | ]; 15 | -------------------------------------------------------------------------------- /resources/views/acl/create.blade.php: -------------------------------------------------------------------------------- 1 | @extends('layouts.app') 2 | @section('content') 3 |
4 |
5 |
6 |
7 |
8 | 添加设备权限 9 |
10 |
11 | @if (count($errors) > 0) 12 |
13 |
    14 | @foreach ($errors->all() as $error) 15 |
  • {{ $error }}
  • 16 | @endforeach 17 |
18 |
19 | @endif 20 |
21 | {{ csrf_field() }} 22 |
23 | 24 | 25 |
26 |
27 | 28 | 32 |
33 |
34 | 35 | 36 |
37 |
38 | 39 | 40 |
41 |
42 | 43 | 48 |
49 |
50 | 51 | 52 |
53 | 54 |
55 |
56 |
57 |
58 |
59 |
60 | @endsection 61 | -------------------------------------------------------------------------------- /resources/views/acl/edit.blade.php: -------------------------------------------------------------------------------- 1 | @extends('layouts.app') 2 | @section('content') 3 |
4 |
5 |
6 |
7 |
8 | 编辑设备权限 9 |
10 |
11 | @if (count($errors) > 0) 12 |
13 |
    14 | @foreach ($errors->all() as $error) 15 |
  • {{ $error }}
  • 16 | @endforeach 17 |
18 |
19 | @endif 20 |
21 | {{ csrf_field() }} 22 | {{ method_field('PUT') }} 23 |
24 | 25 | 26 |
27 |
28 | 29 | 33 |
34 |
35 | 36 | 37 |
38 |
39 | 40 | 41 |
42 |
43 | 44 | 49 |
50 |
51 | 52 | 53 |
54 | 55 |
56 |
57 |
58 |
59 |
60 |
61 | @endsection 62 | -------------------------------------------------------------------------------- /resources/views/acl/index.blade.php: -------------------------------------------------------------------------------- 1 | @extends('layouts.app') 2 | @section('content') 3 |
4 |
5 |
6 | @if (session('status')) 7 |
8 | {{ session('status') }} 9 |
10 | @endif 11 |
12 |
13 | 设备权限列表 14 |
15 |
16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | @forelse ($acls as $acl) 30 | 31 | 32 | 33 | 34 | 35 | 36 | 37 | 40 | 41 | @empty 42 | 43 | @endforelse 44 | 45 |
允许/禁止ip地址用户名设备号权限主题操作
{{ $acl->allowString }}{{ $acl->ipaddr }}{{ $acl->username }}{{ $acl->clientID }}{{ $acl->accessString }}{{ $acl->topic }} 38 | 编辑 | 删除 39 |
您还没有添加任何设备
46 | 63 | 73 | 76 |
77 |
78 |
79 |
80 |
81 | @endsection 82 | -------------------------------------------------------------------------------- /resources/views/auth/login.blade.php: -------------------------------------------------------------------------------- 1 | @extends('layouts.app') 2 | 3 | @section('content') 4 |
5 |
6 |
7 |
8 |
Login
9 |
10 |
11 | {{ csrf_field() }} 12 | 13 |
14 | 15 | 16 |
17 | 18 | 19 | @if ($errors->has('email')) 20 | 21 | {{ $errors->first('email') }} 22 | 23 | @endif 24 |
25 |
26 | 27 |
28 | 29 | 30 |
31 | 32 | 33 | @if ($errors->has('password')) 34 | 35 | {{ $errors->first('password') }} 36 | 37 | @endif 38 |
39 |
40 | 41 |
42 |
43 |
44 | 47 |
48 |
49 |
50 | 51 |
52 |
53 | 56 | 57 | 58 | Forgot Your Password? 59 | 60 |
61 |
62 |
63 |
64 |
65 |
66 |
67 |
68 | @endsection 69 | -------------------------------------------------------------------------------- /resources/views/auth/passwords/email.blade.php: -------------------------------------------------------------------------------- 1 | @extends('layouts.app') 2 | 3 | 4 | @section('content') 5 |
6 |
7 |
8 |
9 |
Reset Password
10 |
11 | @if (session('status')) 12 |
13 | {{ session('status') }} 14 |
15 | @endif 16 | 17 |
18 | {{ csrf_field() }} 19 | 20 |
21 | 22 | 23 |
24 | 25 | 26 | @if ($errors->has('email')) 27 | 28 | {{ $errors->first('email') }} 29 | 30 | @endif 31 |
32 |
33 | 34 |
35 |
36 | 39 |
40 |
41 |
42 |
43 |
44 |
45 |
46 |
47 | @endsection 48 | -------------------------------------------------------------------------------- /resources/views/auth/passwords/reset.blade.php: -------------------------------------------------------------------------------- 1 | @extends('layouts.app') 2 | 3 | @section('content') 4 |
5 |
6 |
7 |
8 |
Reset Password
9 | 10 |
11 | @if (session('status')) 12 |
13 | {{ session('status') }} 14 |
15 | @endif 16 | 17 |
18 | {{ csrf_field() }} 19 | 20 | 21 | 22 |
23 | 24 | 25 |
26 | 27 | 28 | @if ($errors->has('email')) 29 | 30 | {{ $errors->first('email') }} 31 | 32 | @endif 33 |
34 |
35 | 36 |
37 | 38 | 39 |
40 | 41 | 42 | @if ($errors->has('password')) 43 | 44 | {{ $errors->first('password') }} 45 | 46 | @endif 47 |
48 |
49 | 50 |
51 | 52 |
53 | 54 | 55 | @if ($errors->has('password_confirmation')) 56 | 57 | {{ $errors->first('password_confirmation') }} 58 | 59 | @endif 60 |
61 |
62 | 63 |
64 |
65 | 68 |
69 |
70 |
71 |
72 |
73 |
74 |
75 |
76 | @endsection 77 | -------------------------------------------------------------------------------- /resources/views/auth/register.blade.php: -------------------------------------------------------------------------------- 1 | @extends('layouts.app') 2 | 3 | @section('content') 4 |
5 |
6 |
7 |
8 |
Register
9 |
10 |
11 | {{ csrf_field() }} 12 | 13 |
14 | 15 | 16 |
17 | 18 | 19 | @if ($errors->has('name')) 20 | 21 | {{ $errors->first('name') }} 22 | 23 | @endif 24 |
25 |
26 | 27 |
28 | 29 | 30 |
31 | 32 | 33 | @if ($errors->has('email')) 34 | 35 | {{ $errors->first('email') }} 36 | 37 | @endif 38 |
39 |
40 | 41 |
42 | 43 | 44 |
45 | 46 | 47 | @if ($errors->has('password')) 48 | 49 | {{ $errors->first('password') }} 50 | 51 | @endif 52 |
53 |
54 | 55 |
56 | 57 | 58 |
59 | 60 |
61 |
62 | 63 |
64 |
65 | 68 |
69 |
70 |
71 |
72 |
73 |
74 |
75 |
76 | @endsection 77 | -------------------------------------------------------------------------------- /resources/views/device/create.blade.php: -------------------------------------------------------------------------------- 1 | @extends('layouts.app') 2 | 3 | @section('content') 4 |
5 |
6 |
7 |
8 |
9 | 添加设备 10 |
11 |
12 | @if (count($errors) > 0) 13 |
14 |
    15 | @foreach ($errors->all() as $error) 16 |
  • {{ $error }}
  • 17 | @endforeach 18 |
19 |
20 | @endif 21 |
22 | {{ csrf_field() }} 23 |
24 | 25 | 26 |
27 |
28 | 29 | 30 |
31 |
32 | 33 | 34 |
35 |
36 | 37 | 38 |
39 |
40 | 41 | 42 | 43 | 低于a, 显示为红色; a到b之间, 显示为蓝色; 高于b显示为绿色 44 | 45 |
46 | 47 | 48 |
49 |
50 |
51 |
52 |
53 |
54 | @endsection 55 | -------------------------------------------------------------------------------- /resources/views/device/edit.blade.php: -------------------------------------------------------------------------------- 1 | @extends('layouts.app') @section('content') 2 |
3 |
4 |
5 |
6 |
7 | 修改设备 8 |
9 |
10 | @if (count($errors) > 0) 11 |
12 |
    13 | @foreach ($errors->all() as $error) 14 |
  • {{ $error }}
  • 15 | @endforeach 16 |
17 |
18 | @endif 19 |
20 | {{ method_field('PUT') }} 21 | {{ csrf_field() }} 22 |
23 | 24 | 25 |
26 |
27 | 28 | 29 |
30 |
31 | 32 | 33 |
34 |
35 | 36 | 37 |
38 |
39 | 40 | 41 | 42 | 低于a, 显示为红色; a到b之间, 显示为蓝色; 高于b显示为绿色 43 | 44 |
45 | 46 |
47 |
48 |
49 |
50 |
51 |
52 | @endsection 53 | -------------------------------------------------------------------------------- /resources/views/device/show.blade.php: -------------------------------------------------------------------------------- 1 | @extends('layouts.app') 2 | 3 | @section('content') 4 |
5 |
6 |
7 |
8 |
9 |
10 |
11 | 设备状态统计 12 |
13 |
14 | 15 |
16 |
17 |
18 |
19 |
20 | 21 |
22 | 23 | 24 |
25 |
26 |
27 |
28 |

故障报警

29 |
30 |
31 |
32 |

机器运转

33 |
34 |
35 |
36 |

机器做工

37 |
38 |
39 |
40 |

禁止运行

41 |
42 |
43 |
44 | 45 | 46 | 153 |
154 |
155 |
156 |
157 |
158 | @endsection 159 | -------------------------------------------------------------------------------- /resources/views/device/threshold.blade.php: -------------------------------------------------------------------------------- 1 | @extends('layouts.app') 2 | 3 | @section('content') 4 |
5 |
6 |
7 |
8 |
9 | 设备默认阀值设置 10 |
11 |
12 | @if (count($errors) > 0) 13 |
14 |
    15 | @foreach ($errors->all() as $error) 16 |
  • {{ $error }}
  • 17 | @endforeach 18 |
19 |
20 | @endif 21 |
22 | {{ csrf_field() }} 23 | {{ method_field('PUT') }} 24 |
25 | 26 | 27 |
28 | 29 | 30 |
31 |
32 |
33 |
34 |
35 |
36 | @endsection 37 | -------------------------------------------------------------------------------- /resources/views/emails/foo.blade.php: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/tennessine/laravel-project/a0743790c5e900766ff93fbf083abd2ccc9c7952/resources/views/emails/foo.blade.php -------------------------------------------------------------------------------- /resources/views/errors/503.blade.php: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | Be right back. 5 | 6 | 7 | 8 | 39 | 40 | 41 |
42 |
43 |
Be right back.
44 |
45 |
46 | 47 | 48 | -------------------------------------------------------------------------------- /resources/views/home.blade.php: -------------------------------------------------------------------------------- 1 | @extends('layouts.app') 2 | 3 | @section('content') 4 |
5 |
6 |
7 |
8 |
Dashboard
9 | 10 |
11 | You are logged in! 12 |
13 |
14 |
15 |
16 |
17 | @endsection 18 | -------------------------------------------------------------------------------- /resources/views/layouts/app.blade.php: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | {{ config('app.name', 'Laravel') }} 12 | 13 | 14 | 15 | 16 | 17 | 20 | 21 | 22 |
23 | 114 | 115 | 116 | 117 | 118 | @yield('content') 119 |
120 | 121 | 122 | -------------------------------------------------------------------------------- /resources/views/user/create.blade.php: -------------------------------------------------------------------------------- 1 | @extends('layouts.app') @section('content') 2 |
3 |
4 |
5 |
6 |
7 | 添加管理员 8 |
9 |
10 | @if (count($errors) > 0) 11 |
12 |
    13 | @foreach ($errors->all() as $error) 14 |
  • {{ $error }}
  • 15 | @endforeach 16 |
17 |
18 | @endif 19 |
20 | {{ csrf_field() }} 21 |
22 | 23 | 24 |
25 |
26 | 27 | 28 |
29 |
30 | 31 | 32 |
33 | 34 |
35 |
36 |
37 |
38 |
39 |
40 | @endsection 41 | -------------------------------------------------------------------------------- /resources/views/user/edit.blade.php: -------------------------------------------------------------------------------- 1 | @extends('layouts.app') @section('content') 2 |
3 |
4 |
5 |
6 |
7 | 添加管理员 8 |
9 |
10 | @if (count($errors) > 0) 11 |
12 |
    13 | @foreach ($errors->all() as $error) 14 |
  • {{ $error }}
  • 15 | @endforeach 16 |
17 |
18 | @endif 19 |
20 | {{ method_field('PUT') }} 21 | {{ csrf_field() }} 22 |
23 | 24 | 25 |
26 |
27 | 28 | 29 |
30 |
31 | 32 | 33 |
34 | 35 |
36 |
37 |
38 |
39 |
40 |
41 | @endsection 42 | -------------------------------------------------------------------------------- /resources/views/user/index.blade.php: -------------------------------------------------------------------------------- 1 | @extends('layouts.app') 2 | @section('content') 3 |
4 |
5 |
6 | @if (session('status')) 7 |
8 | {{ session('status') }} 9 |
10 | @endif 11 |
12 |
13 | 管理员列表 14 |
15 |
16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | @forelse ($users as $user) 27 | 28 | 29 | 30 | 31 | 34 | 35 | @empty 36 | 37 | @endforelse 38 | 39 |
用户名邮箱添加时间操作
{{ $user->name }}{{ $user->email }}{{ $user->created_at }} 32 | 编辑 | 删除 33 |
您还没有添加任何设备
40 | 57 | 67 | 70 |
71 |
72 |
73 |
74 |
75 | @endsection 76 | -------------------------------------------------------------------------------- /resources/views/vendor/.gitkeep: -------------------------------------------------------------------------------- 1 | 2 | -------------------------------------------------------------------------------- /resources/views/vendor/notifications/email-plain.blade.php: -------------------------------------------------------------------------------- 1 | hasPages()) 2 | 36 | @endif 37 | -------------------------------------------------------------------------------- /resources/views/vendor/pagination/default.blade.php: -------------------------------------------------------------------------------- 1 | @if ($paginator->hasPages()) 2 | 36 | @endif 37 | -------------------------------------------------------------------------------- /resources/views/vendor/pagination/simple-bootstrap-4.blade.php: -------------------------------------------------------------------------------- 1 | @if ($paginator->hasPages()) 2 | 17 | @endif 18 | -------------------------------------------------------------------------------- /resources/views/vendor/pagination/simple-default.blade.php: -------------------------------------------------------------------------------- 1 | @if ($paginator->hasPages()) 2 | 17 | @endif 18 | -------------------------------------------------------------------------------- /resources/views/welcome.blade.php: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | Laravel 8 | 9 | 10 | 11 | 12 | 13 | 65 | 66 | 67 |
68 | @if (Route::has('login')) 69 | 73 | @endif 74 | 75 |
76 |
77 | Laravel 78 |
79 | 80 | 87 |
88 |
89 | 90 | 91 | -------------------------------------------------------------------------------- /routes/api.php: -------------------------------------------------------------------------------- 1 | user(); 18 | })->middleware('auth:api'); 19 | -------------------------------------------------------------------------------- /routes/console.php: -------------------------------------------------------------------------------- 1 | comment(Inspiring::quote()); 18 | })->describe('Display an inspiring quote'); 19 | 20 | Artisan::command('build {user : The id of the user} {--id=* : ids of the user}', function ($id) { 21 | var_dump($id); 22 | }); 23 | -------------------------------------------------------------------------------- /routes/web.php: -------------------------------------------------------------------------------- 1 | name('device.threshold'); 8 | Route::put('/device/threshold', 'DeviceController@threshold')->name('device.threshold'); 9 | Route::resource('device', 'DeviceController', ['except' => ['show']]); 10 | Route::get('/device/{device}/{time}', 'DeviceController@show')->name('device.show'); 11 | 12 | Route::resource('user', 'UserController'); 13 | Route::resource('acl', 'AclController'); 14 | 15 | Route::get('/', 'HomeController@index'); -------------------------------------------------------------------------------- /server.php: -------------------------------------------------------------------------------- 1 | 8 | */ 9 | 10 | $uri = urldecode( 11 | parse_url($_SERVER['REQUEST_URI'], PHP_URL_PATH) 12 | ); 13 | 14 | // This file allows us to emulate Apache's "mod_rewrite" functionality from the 15 | // built-in PHP web server. This provides a convenient way to test a Laravel 16 | // application without having installed a "real" web server software here. 17 | if ($uri !== '/' && file_exists(__DIR__.'/public'.$uri)) { 18 | return false; 19 | } 20 | 21 | require_once __DIR__.'/public/index.php'; 22 | -------------------------------------------------------------------------------- /storage/app/.gitignore: -------------------------------------------------------------------------------- 1 | * 2 | !public/ 3 | !.gitignore 4 | -------------------------------------------------------------------------------- /storage/app/public/.gitignore: -------------------------------------------------------------------------------- 1 | * 2 | !.gitignore 3 | -------------------------------------------------------------------------------- /storage/framework/.gitignore: -------------------------------------------------------------------------------- 1 | config.php 2 | routes.php 3 | schedule-* 4 | compiled.php 5 | services.json 6 | events.scanned.php 7 | routes.scanned.php 8 | down 9 | -------------------------------------------------------------------------------- /storage/framework/cache/.gitignore: -------------------------------------------------------------------------------- 1 | * 2 | !.gitignore 3 | -------------------------------------------------------------------------------- /storage/framework/sessions/.gitignore: -------------------------------------------------------------------------------- 1 | * 2 | !.gitignore 3 | -------------------------------------------------------------------------------- /storage/framework/views/.gitignore: -------------------------------------------------------------------------------- 1 | * 2 | !.gitignore 3 | -------------------------------------------------------------------------------- /storage/logs/.gitignore: -------------------------------------------------------------------------------- 1 | * 2 | !.gitignore 3 | -------------------------------------------------------------------------------- /tests/ExampleTest.php: -------------------------------------------------------------------------------- 1 | visit('/') 17 | ->see('Laravel'); 18 | } 19 | } 20 | -------------------------------------------------------------------------------- /tests/TestCase.php: -------------------------------------------------------------------------------- 1 | make(Illuminate\Contracts\Console\Kernel::class)->bootstrap(); 22 | 23 | return $app; 24 | } 25 | } 26 | -------------------------------------------------------------------------------- /ubuntu.sh: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/tennessine/laravel-project/a0743790c5e900766ff93fbf083abd2ccc9c7952/ubuntu.sh --------------------------------------------------------------------------------