148 changed files with 27599 additions and 0 deletions
Split View
Diff Options
-
33BackEnd/London/.gitignore
-
117BackEnd/London/.mvn/wrapper/MavenWrapperDownloader.java
-
BINBackEnd/London/.mvn/wrapper/maven-wrapper.jar
-
2BackEnd/London/.mvn/wrapper/maven-wrapper.properties
-
33BackEnd/London/bin/.gitignore
-
BINBackEnd/London/bin/.mvn/wrapper/MavenWrapperDownloader.class
-
BINBackEnd/London/bin/.mvn/wrapper/maven-wrapper.jar
-
2BackEnd/London/bin/.mvn/wrapper/maven-wrapper.properties
-
310BackEnd/London/bin/mvnw
-
182BackEnd/London/bin/mvnw.cmd
-
76BackEnd/London/bin/pom.xml
-
BINBackEnd/London/bin/src/main/java/com/example/londonStore/CorsConfig.class
-
BINBackEnd/London/bin/src/main/java/com/example/londonStore/LondonApplication.class
-
BINBackEnd/London/bin/src/main/java/com/example/londonStore/SecurityConfig.class
-
BINBackEnd/London/bin/src/main/java/com/example/londonStore/controller/HomeController.class
-
BINBackEnd/London/bin/src/main/java/com/example/londonStore/controller/UserController.class
-
BINBackEnd/London/bin/src/main/java/com/example/londonStore/model/Category.class
-
BINBackEnd/London/bin/src/main/java/com/example/londonStore/model/User.class
-
BINBackEnd/London/bin/src/main/java/com/example/londonStore/repository/CategoryRepo.class
-
BINBackEnd/London/bin/src/main/java/com/example/londonStore/repository/UserRepository.class
-
BINBackEnd/London/bin/src/main/java/com/example/londonStore/service/Home.class
-
BINBackEnd/London/bin/src/main/java/com/example/londonStore/service/MyUserDetailsService.class
-
10BackEnd/London/bin/src/main/resources/application.properties
-
BINBackEnd/London/bin/src/test/java/com/example/londonStore/LondonApplicationTests.class
-
310BackEnd/London/mvnw
-
182BackEnd/London/mvnw.cmd
-
76BackEnd/London/pom.xml
-
14BackEnd/London/src/main/java/com/example/londonStore/CorsConfig.java
-
31BackEnd/London/src/main/java/com/example/londonStore/LondonApplication.java
-
56BackEnd/London/src/main/java/com/example/londonStore/SecurityConfig.java
-
30BackEnd/London/src/main/java/com/example/londonStore/controller/HomeController.java
-
76BackEnd/London/src/main/java/com/example/londonStore/controller/UserController.java
-
27BackEnd/London/src/main/java/com/example/londonStore/model/Category.java
-
111BackEnd/London/src/main/java/com/example/londonStore/model/User.java
-
11BackEnd/London/src/main/java/com/example/londonStore/repository/CategoryRepo.java
-
14BackEnd/London/src/main/java/com/example/londonStore/repository/UserRepository.java
-
27BackEnd/London/src/main/java/com/example/londonStore/service/Home.java
-
25BackEnd/London/src/main/java/com/example/londonStore/service/MyUserDetailsService.java
-
10BackEnd/London/src/main/resources/application.properties
-
13BackEnd/London/src/test/java/com/example/londonStore/LondonApplicationTests.java
-
17FrontEnd/.browserslistrc
-
16FrontEnd/.editorconfig
-
45FrontEnd/.gitignore
-
27FrontEnd/README.md
-
110FrontEnd/angular.json
-
44FrontEnd/karma.conf.js
-
12122FrontEnd/package-lock.json
-
39FrontEnd/package.json
-
12FrontEnd/proxy.conf.json
-
42FrontEnd/src/app/app-routing.module.ts
-
0FrontEnd/src/app/app.component.css
-
2FrontEnd/src/app/app.component.html
-
35FrontEnd/src/app/app.component.spec.ts
-
10FrontEnd/src/app/app.component.ts
-
38FrontEnd/src/app/app.module.ts
-
0FrontEnd/src/app/auth/login/login.component.css
-
46FrontEnd/src/app/auth/login/login.component.html
-
25FrontEnd/src/app/auth/login/login.component.spec.ts
-
43FrontEnd/src/app/auth/login/login.component.ts
-
16FrontEnd/src/app/auth/service/auth-guard.service.spec.ts
-
20FrontEnd/src/app/auth/service/auth-guard.service.ts
-
16FrontEnd/src/app/auth/service/auth.service.spec.ts
-
17FrontEnd/src/app/auth/service/auth.service.ts
-
0FrontEnd/src/app/auth/sign-up/sign-up.component.css
-
89FrontEnd/src/app/auth/sign-up/sign-up.component.html
-
25FrontEnd/src/app/auth/sign-up/sign-up.component.spec.ts
-
48FrontEnd/src/app/auth/sign-up/sign-up.component.ts
-
0FrontEnd/src/app/component/account/account.component.css
-
87FrontEnd/src/app/component/account/account.component.html
-
25FrontEnd/src/app/component/account/account.component.spec.ts
-
51FrontEnd/src/app/component/account/account.component.ts
-
0FrontEnd/src/app/component/catalog/catalog.component.css
-
152FrontEnd/src/app/component/catalog/catalog.component.html
-
25FrontEnd/src/app/component/catalog/catalog.component.spec.ts
-
43FrontEnd/src/app/component/catalog/catalog.component.ts
-
3FrontEnd/src/app/component/home/home.component.css
-
27FrontEnd/src/app/component/home/home.component.html
-
25FrontEnd/src/app/component/home/home.component.spec.ts
-
16FrontEnd/src/app/component/home/home.component.ts
-
0FrontEnd/src/app/component/navbar/navbar.component.css
-
42FrontEnd/src/app/component/navbar/navbar.component.html
-
25FrontEnd/src/app/component/navbar/navbar.component.spec.ts
-
62FrontEnd/src/app/component/navbar/navbar.component.ts
-
0FrontEnd/src/app/component/pagenotfound/pagenotfound.component.css
-
1FrontEnd/src/app/component/pagenotfound/pagenotfound.component.html
-
25FrontEnd/src/app/component/pagenotfound/pagenotfound.component.spec.ts
-
15FrontEnd/src/app/component/pagenotfound/pagenotfound.component.ts
-
0FrontEnd/src/app/component/product/product.component.css
-
166FrontEnd/src/app/component/product/product.component.html
-
25FrontEnd/src/app/component/product/product.component.spec.ts
-
32FrontEnd/src/app/component/product/product.component.ts
-
11FrontEnd/src/app/model/product.model.ts
-
8FrontEnd/src/app/model/user.model.ts
-
16FrontEnd/src/app/service/appservice.service.spec.ts
-
16FrontEnd/src/app/service/appservice.service.ts
-
16FrontEnd/src/app/service/product.service.spec.ts
-
41FrontEnd/src/app/service/product.service.ts
-
16FrontEnd/src/app/service/user-service.service.spec.ts
-
67FrontEnd/src/app/service/user-service.service.ts
-
0FrontEnd/src/assets/.gitkeep
@ -0,0 +1,33 @@ |
|||
HELP.md |
|||
target/ |
|||
!.mvn/wrapper/maven-wrapper.jar |
|||
!**/src/main/**/target/ |
|||
!**/src/test/**/target/ |
|||
|
|||
### STS ### |
|||
.apt_generated |
|||
.classpath |
|||
.factorypath |
|||
.project |
|||
.settings |
|||
.springBeans |
|||
.sts4-cache |
|||
|
|||
### IntelliJ IDEA ### |
|||
.idea |
|||
*.iws |
|||
*.iml |
|||
*.ipr |
|||
|
|||
### NetBeans ### |
|||
/nbproject/private/ |
|||
/nbbuild/ |
|||
/dist/ |
|||
/nbdist/ |
|||
/.nb-gradle/ |
|||
build/ |
|||
!**/src/main/**/build/ |
|||
!**/src/test/**/build/ |
|||
|
|||
### VS Code ### |
|||
.vscode/ |
|||
@ -0,0 +1,117 @@ |
|||
/* |
|||
* Copyright 2007-present the original author or authors. |
|||
* |
|||
* Licensed under the Apache License, Version 2.0 (the "License"); |
|||
* you may not use this file except in compliance with the License. |
|||
* You may obtain a copy of the License at |
|||
* |
|||
* https://www.apache.org/licenses/LICENSE-2.0 |
|||
* |
|||
* Unless required by applicable law or agreed to in writing, software |
|||
* distributed under the License is distributed on an "AS IS" BASIS, |
|||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
|||
* See the License for the specific language governing permissions and |
|||
* limitations under the License. |
|||
*/ |
|||
import java.net.*; |
|||
import java.io.*; |
|||
import java.nio.channels.*; |
|||
import java.util.Properties; |
|||
|
|||
public class MavenWrapperDownloader { |
|||
|
|||
private static final String WRAPPER_VERSION = "0.5.6"; |
|||
/** |
|||
* Default URL to download the maven-wrapper.jar from, if no 'downloadUrl' is provided. |
|||
*/ |
|||
private static final String DEFAULT_DOWNLOAD_URL = "https://repo.maven.apache.org/maven2/io/takari/maven-wrapper/" |
|||
+ WRAPPER_VERSION + "/maven-wrapper-" + WRAPPER_VERSION + ".jar"; |
|||
|
|||
/** |
|||
* Path to the maven-wrapper.properties file, which might contain a downloadUrl property to |
|||
* use instead of the default one. |
|||
*/ |
|||
private static final String MAVEN_WRAPPER_PROPERTIES_PATH = |
|||
".mvn/wrapper/maven-wrapper.properties"; |
|||
|
|||
/** |
|||
* Path where the maven-wrapper.jar will be saved to. |
|||
*/ |
|||
private static final String MAVEN_WRAPPER_JAR_PATH = |
|||
".mvn/wrapper/maven-wrapper.jar"; |
|||
|
|||
/** |
|||
* Name of the property which should be used to override the default download url for the wrapper. |
|||
*/ |
|||
private static final String PROPERTY_NAME_WRAPPER_URL = "wrapperUrl"; |
|||
|
|||
public static void main(String args[]) { |
|||
System.out.println("- Downloader started"); |
|||
File baseDirectory = new File(args[0]); |
|||
System.out.println("- Using base directory: " + baseDirectory.getAbsolutePath()); |
|||
|
|||
// If the maven-wrapper.properties exists, read it and check if it contains a custom |
|||
// wrapperUrl parameter. |
|||
File mavenWrapperPropertyFile = new File(baseDirectory, MAVEN_WRAPPER_PROPERTIES_PATH); |
|||
String url = DEFAULT_DOWNLOAD_URL; |
|||
if(mavenWrapperPropertyFile.exists()) { |
|||
FileInputStream mavenWrapperPropertyFileInputStream = null; |
|||
try { |
|||
mavenWrapperPropertyFileInputStream = new FileInputStream(mavenWrapperPropertyFile); |
|||
Properties mavenWrapperProperties = new Properties(); |
|||
mavenWrapperProperties.load(mavenWrapperPropertyFileInputStream); |
|||
url = mavenWrapperProperties.getProperty(PROPERTY_NAME_WRAPPER_URL, url); |
|||
} catch (IOException e) { |
|||
System.out.println("- ERROR loading '" + MAVEN_WRAPPER_PROPERTIES_PATH + "'"); |
|||
} finally { |
|||
try { |
|||
if(mavenWrapperPropertyFileInputStream != null) { |
|||
mavenWrapperPropertyFileInputStream.close(); |
|||
} |
|||
} catch (IOException e) { |
|||
// Ignore ... |
|||
} |
|||
} |
|||
} |
|||
System.out.println("- Downloading from: " + url); |
|||
|
|||
File outputFile = new File(baseDirectory.getAbsolutePath(), MAVEN_WRAPPER_JAR_PATH); |
|||
if(!outputFile.getParentFile().exists()) { |
|||
if(!outputFile.getParentFile().mkdirs()) { |
|||
System.out.println( |
|||
"- ERROR creating output directory '" + outputFile.getParentFile().getAbsolutePath() + "'"); |
|||
} |
|||
} |
|||
System.out.println("- Downloading to: " + outputFile.getAbsolutePath()); |
|||
try { |
|||
downloadFileFromURL(url, outputFile); |
|||
System.out.println("Done"); |
|||
System.exit(0); |
|||
} catch (Throwable e) { |
|||
System.out.println("- Error downloading"); |
|||
e.printStackTrace(); |
|||
System.exit(1); |
|||
} |
|||
} |
|||
|
|||
private static void downloadFileFromURL(String urlString, File destination) throws Exception { |
|||
if (System.getenv("MVNW_USERNAME") != null && System.getenv("MVNW_PASSWORD") != null) { |
|||
String username = System.getenv("MVNW_USERNAME"); |
|||
char[] password = System.getenv("MVNW_PASSWORD").toCharArray(); |
|||
Authenticator.setDefault(new Authenticator() { |
|||
@Override |
|||
protected PasswordAuthentication getPasswordAuthentication() { |
|||
return new PasswordAuthentication(username, password); |
|||
} |
|||
}); |
|||
} |
|||
URL website = new URL(urlString); |
|||
ReadableByteChannel rbc; |
|||
rbc = Channels.newChannel(website.openStream()); |
|||
FileOutputStream fos = new FileOutputStream(destination); |
|||
fos.getChannel().transferFrom(rbc, 0, Long.MAX_VALUE); |
|||
fos.close(); |
|||
rbc.close(); |
|||
} |
|||
|
|||
} |
|||
@ -0,0 +1,2 @@ |
|||
distributionUrl=https://repo.maven.apache.org/maven2/org/apache/maven/apache-maven/3.8.2/apache-maven-3.8.2-bin.zip |
|||
wrapperUrl=https://repo.maven.apache.org/maven2/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar |
|||
@ -0,0 +1,33 @@ |
|||
HELP.md |
|||
target/ |
|||
!.mvn/wrapper/maven-wrapper.jar |
|||
!**/src/main/**/target/ |
|||
!**/src/test/**/target/ |
|||
|
|||
### STS ### |
|||
.apt_generated |
|||
.classpath |
|||
.factorypath |
|||
.project |
|||
.settings |
|||
.springBeans |
|||
.sts4-cache |
|||
|
|||
### IntelliJ IDEA ### |
|||
.idea |
|||
*.iws |
|||
*.iml |
|||
*.ipr |
|||
|
|||
### NetBeans ### |
|||
/nbproject/private/ |
|||
/nbbuild/ |
|||
/dist/ |
|||
/nbdist/ |
|||
/.nb-gradle/ |
|||
build/ |
|||
!**/src/main/**/build/ |
|||
!**/src/test/**/build/ |
|||
|
|||
### VS Code ### |
|||
.vscode/ |
|||
@ -0,0 +1,2 @@ |
|||
distributionUrl=https://repo.maven.apache.org/maven2/org/apache/maven/apache-maven/3.8.2/apache-maven-3.8.2-bin.zip |
|||
wrapperUrl=https://repo.maven.apache.org/maven2/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar |
|||
@ -0,0 +1,310 @@ |
|||
#!/bin/sh |
|||
# ---------------------------------------------------------------------------- |
|||
# Licensed to the Apache Software Foundation (ASF) under one |
|||
# or more contributor license agreements. See the NOTICE file |
|||
# distributed with this work for additional information |
|||
# regarding copyright ownership. The ASF licenses this file |
|||
# to you under the Apache License, Version 2.0 (the |
|||
# "License"); you may not use this file except in compliance |
|||
# with the License. You may obtain a copy of the License at |
|||
# |
|||
# https://www.apache.org/licenses/LICENSE-2.0 |
|||
# |
|||
# Unless required by applicable law or agreed to in writing, |
|||
# software distributed under the License is distributed on an |
|||
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
|||
# KIND, either express or implied. See the License for the |
|||
# specific language governing permissions and limitations |
|||
# under the License. |
|||
# ---------------------------------------------------------------------------- |
|||
|
|||
# ---------------------------------------------------------------------------- |
|||
# Maven Start Up Batch script |
|||
# |
|||
# Required ENV vars: |
|||
# ------------------ |
|||
# JAVA_HOME - location of a JDK home dir |
|||
# |
|||
# Optional ENV vars |
|||
# ----------------- |
|||
# M2_HOME - location of maven2's installed home dir |
|||
# MAVEN_OPTS - parameters passed to the Java VM when running Maven |
|||
# e.g. to debug Maven itself, use |
|||
# set MAVEN_OPTS=-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8000 |
|||
# MAVEN_SKIP_RC - flag to disable loading of mavenrc files |
|||
# ---------------------------------------------------------------------------- |
|||
|
|||
if [ -z "$MAVEN_SKIP_RC" ] ; then |
|||
|
|||
if [ -f /etc/mavenrc ] ; then |
|||
. /etc/mavenrc |
|||
fi |
|||
|
|||
if [ -f "$HOME/.mavenrc" ] ; then |
|||
. "$HOME/.mavenrc" |
|||
fi |
|||
|
|||
fi |
|||
|
|||
# OS specific support. $var _must_ be set to either true or false. |
|||
cygwin=false; |
|||
darwin=false; |
|||
mingw=false |
|||
case "`uname`" in |
|||
CYGWIN*) cygwin=true ;; |
|||
MINGW*) mingw=true;; |
|||
Darwin*) darwin=true |
|||
# Use /usr/libexec/java_home if available, otherwise fall back to /Library/Java/Home |
|||
# See https://developer.apple.com/library/mac/qa/qa1170/_index.html |
|||
if [ -z "$JAVA_HOME" ]; then |
|||
if [ -x "/usr/libexec/java_home" ]; then |
|||
export JAVA_HOME="`/usr/libexec/java_home`" |
|||
else |
|||
export JAVA_HOME="/Library/Java/Home" |
|||
fi |
|||
fi |
|||
;; |
|||
esac |
|||
|
|||
if [ -z "$JAVA_HOME" ] ; then |
|||
if [ -r /etc/gentoo-release ] ; then |
|||
JAVA_HOME=`java-config --jre-home` |
|||
fi |
|||
fi |
|||
|
|||
if [ -z "$M2_HOME" ] ; then |
|||
## resolve links - $0 may be a link to maven's home |
|||
PRG="$0" |
|||
|
|||
# need this for relative symlinks |
|||
while [ -h "$PRG" ] ; do |
|||
ls=`ls -ld "$PRG"` |
|||
link=`expr "$ls" : '.*-> \(.*\)$'` |
|||
if expr "$link" : '/.*' > /dev/null; then |
|||
PRG="$link" |
|||
else |
|||
PRG="`dirname "$PRG"`/$link" |
|||
fi |
|||
done |
|||
|
|||
saveddir=`pwd` |
|||
|
|||
M2_HOME=`dirname "$PRG"`/.. |
|||
|
|||
# make it fully qualified |
|||
M2_HOME=`cd "$M2_HOME" && pwd` |
|||
|
|||
cd "$saveddir" |
|||
# echo Using m2 at $M2_HOME |
|||
fi |
|||
|
|||
# For Cygwin, ensure paths are in UNIX format before anything is touched |
|||
if $cygwin ; then |
|||
[ -n "$M2_HOME" ] && |
|||
M2_HOME=`cygpath --unix "$M2_HOME"` |
|||
[ -n "$JAVA_HOME" ] && |
|||
JAVA_HOME=`cygpath --unix "$JAVA_HOME"` |
|||
[ -n "$CLASSPATH" ] && |
|||
CLASSPATH=`cygpath --path --unix "$CLASSPATH"` |
|||
fi |
|||
|
|||
# For Mingw, ensure paths are in UNIX format before anything is touched |
|||
if $mingw ; then |
|||
[ -n "$M2_HOME" ] && |
|||
M2_HOME="`(cd "$M2_HOME"; pwd)`" |
|||
[ -n "$JAVA_HOME" ] && |
|||
JAVA_HOME="`(cd "$JAVA_HOME"; pwd)`" |
|||
fi |
|||
|
|||
if [ -z "$JAVA_HOME" ]; then |
|||
javaExecutable="`which javac`" |
|||
if [ -n "$javaExecutable" ] && ! [ "`expr \"$javaExecutable\" : '\([^ ]*\)'`" = "no" ]; then |
|||
# readlink(1) is not available as standard on Solaris 10. |
|||
readLink=`which readlink` |
|||
if [ ! `expr "$readLink" : '\([^ ]*\)'` = "no" ]; then |
|||
if $darwin ; then |
|||
javaHome="`dirname \"$javaExecutable\"`" |
|||
javaExecutable="`cd \"$javaHome\" && pwd -P`/javac" |
|||
else |
|||
javaExecutable="`readlink -f \"$javaExecutable\"`" |
|||
fi |
|||
javaHome="`dirname \"$javaExecutable\"`" |
|||
javaHome=`expr "$javaHome" : '\(.*\)/bin'` |
|||
JAVA_HOME="$javaHome" |
|||
export JAVA_HOME |
|||
fi |
|||
fi |
|||
fi |
|||
|
|||
if [ -z "$JAVACMD" ] ; then |
|||
if [ -n "$JAVA_HOME" ] ; then |
|||
if [ -x "$JAVA_HOME/jre/sh/java" ] ; then |
|||
# IBM's JDK on AIX uses strange locations for the executables |
|||
JAVACMD="$JAVA_HOME/jre/sh/java" |
|||
else |
|||
JAVACMD="$JAVA_HOME/bin/java" |
|||
fi |
|||
else |
|||
JAVACMD="`which java`" |
|||
fi |
|||
fi |
|||
|
|||
if [ ! -x "$JAVACMD" ] ; then |
|||
echo "Error: JAVA_HOME is not defined correctly." >&2 |
|||
echo " We cannot execute $JAVACMD" >&2 |
|||
exit 1 |
|||
fi |
|||
|
|||
if [ -z "$JAVA_HOME" ] ; then |
|||
echo "Warning: JAVA_HOME environment variable is not set." |
|||
fi |
|||
|
|||
CLASSWORLDS_LAUNCHER=org.codehaus.plexus.classworlds.launcher.Launcher |
|||
|
|||
# traverses directory structure from process work directory to filesystem root |
|||
# first directory with .mvn subdirectory is considered project base directory |
|||
find_maven_basedir() { |
|||
|
|||
if [ -z "$1" ] |
|||
then |
|||
echo "Path not specified to find_maven_basedir" |
|||
return 1 |
|||
fi |
|||
|
|||
basedir="$1" |
|||
wdir="$1" |
|||
while [ "$wdir" != '/' ] ; do |
|||
if [ -d "$wdir"/.mvn ] ; then |
|||
basedir=$wdir |
|||
break |
|||
fi |
|||
# workaround for JBEAP-8937 (on Solaris 10/Sparc) |
|||
if [ -d "${wdir}" ]; then |
|||
wdir=`cd "$wdir/.."; pwd` |
|||
fi |
|||
# end of workaround |
|||
done |
|||
echo "${basedir}" |
|||
} |
|||
|
|||
# concatenates all lines of a file |
|||
concat_lines() { |
|||
if [ -f "$1" ]; then |
|||
echo "$(tr -s '\n' ' ' < "$1")" |
|||
fi |
|||
} |
|||
|
|||
BASE_DIR=`find_maven_basedir "$(pwd)"` |
|||
if [ -z "$BASE_DIR" ]; then |
|||
exit 1; |
|||
fi |
|||
|
|||
########################################################################################## |
|||
# Extension to allow automatically downloading the maven-wrapper.jar from Maven-central |
|||
# This allows using the maven wrapper in projects that prohibit checking in binary data. |
|||
########################################################################################## |
|||
if [ -r "$BASE_DIR/.mvn/wrapper/maven-wrapper.jar" ]; then |
|||
if [ "$MVNW_VERBOSE" = true ]; then |
|||
echo "Found .mvn/wrapper/maven-wrapper.jar" |
|||
fi |
|||
else |
|||
if [ "$MVNW_VERBOSE" = true ]; then |
|||
echo "Couldn't find .mvn/wrapper/maven-wrapper.jar, downloading it ..." |
|||
fi |
|||
if [ -n "$MVNW_REPOURL" ]; then |
|||
jarUrl="$MVNW_REPOURL/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar" |
|||
else |
|||
jarUrl="https://repo.maven.apache.org/maven2/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar" |
|||
fi |
|||
while IFS="=" read key value; do |
|||
case "$key" in (wrapperUrl) jarUrl="$value"; break ;; |
|||
esac |
|||
done < "$BASE_DIR/.mvn/wrapper/maven-wrapper.properties" |
|||
if [ "$MVNW_VERBOSE" = true ]; then |
|||
echo "Downloading from: $jarUrl" |
|||
fi |
|||
wrapperJarPath="$BASE_DIR/.mvn/wrapper/maven-wrapper.jar" |
|||
if $cygwin; then |
|||
wrapperJarPath=`cygpath --path --windows "$wrapperJarPath"` |
|||
fi |
|||
|
|||
if command -v wget > /dev/null; then |
|||
if [ "$MVNW_VERBOSE" = true ]; then |
|||
echo "Found wget ... using wget" |
|||
fi |
|||
if [ -z "$MVNW_USERNAME" ] || [ -z "$MVNW_PASSWORD" ]; then |
|||
wget "$jarUrl" -O "$wrapperJarPath" |
|||
else |
|||
wget --http-user=$MVNW_USERNAME --http-password=$MVNW_PASSWORD "$jarUrl" -O "$wrapperJarPath" |
|||
fi |
|||
elif command -v curl > /dev/null; then |
|||
if [ "$MVNW_VERBOSE" = true ]; then |
|||
echo "Found curl ... using curl" |
|||
fi |
|||
if [ -z "$MVNW_USERNAME" ] || [ -z "$MVNW_PASSWORD" ]; then |
|||
curl -o "$wrapperJarPath" "$jarUrl" -f |
|||
else |
|||
curl --user $MVNW_USERNAME:$MVNW_PASSWORD -o "$wrapperJarPath" "$jarUrl" -f |
|||
fi |
|||
|
|||
else |
|||
if [ "$MVNW_VERBOSE" = true ]; then |
|||
echo "Falling back to using Java to download" |
|||
fi |
|||
javaClass="$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.java" |
|||
# For Cygwin, switch paths to Windows format before running javac |
|||
if $cygwin; then |
|||
javaClass=`cygpath --path --windows "$javaClass"` |
|||
fi |
|||
if [ -e "$javaClass" ]; then |
|||
if [ ! -e "$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.class" ]; then |
|||
if [ "$MVNW_VERBOSE" = true ]; then |
|||
echo " - Compiling MavenWrapperDownloader.java ..." |
|||
fi |
|||
# Compiling the Java class |
|||
("$JAVA_HOME/bin/javac" "$javaClass") |
|||
fi |
|||
if [ -e "$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.class" ]; then |
|||
# Running the downloader |
|||
if [ "$MVNW_VERBOSE" = true ]; then |
|||
echo " - Running MavenWrapperDownloader.java ..." |
|||
fi |
|||
("$JAVA_HOME/bin/java" -cp .mvn/wrapper MavenWrapperDownloader "$MAVEN_PROJECTBASEDIR") |
|||
fi |
|||
fi |
|||
fi |
|||
fi |
|||
########################################################################################## |
|||
# End of extension |
|||
########################################################################################## |
|||
|
|||
export MAVEN_PROJECTBASEDIR=${MAVEN_BASEDIR:-"$BASE_DIR"} |
|||
if [ "$MVNW_VERBOSE" = true ]; then |
|||
echo $MAVEN_PROJECTBASEDIR |
|||
fi |
|||
MAVEN_OPTS="$(concat_lines "$MAVEN_PROJECTBASEDIR/.mvn/jvm.config") $MAVEN_OPTS" |
|||
|
|||
# For Cygwin, switch paths to Windows format before running java |
|||
if $cygwin; then |
|||
[ -n "$M2_HOME" ] && |
|||
M2_HOME=`cygpath --path --windows "$M2_HOME"` |
|||
[ -n "$JAVA_HOME" ] && |
|||
JAVA_HOME=`cygpath --path --windows "$JAVA_HOME"` |
|||
[ -n "$CLASSPATH" ] && |
|||
CLASSPATH=`cygpath --path --windows "$CLASSPATH"` |
|||
[ -n "$MAVEN_PROJECTBASEDIR" ] && |
|||
MAVEN_PROJECTBASEDIR=`cygpath --path --windows "$MAVEN_PROJECTBASEDIR"` |
|||
fi |
|||
|
|||
# Provide a "standardized" way to retrieve the CLI args that will |
|||
# work with both Windows and non-Windows executions. |
|||
MAVEN_CMD_LINE_ARGS="$MAVEN_CONFIG $@" |
|||
export MAVEN_CMD_LINE_ARGS |
|||
|
|||
WRAPPER_LAUNCHER=org.apache.maven.wrapper.MavenWrapperMain |
|||
|
|||
exec "$JAVACMD" \ |
|||
$MAVEN_OPTS \ |
|||
-classpath "$MAVEN_PROJECTBASEDIR/.mvn/wrapper/maven-wrapper.jar" \ |
|||
"-Dmaven.home=${M2_HOME}" "-Dmaven.multiModuleProjectDirectory=${MAVEN_PROJECTBASEDIR}" \ |
|||
${WRAPPER_LAUNCHER} $MAVEN_CONFIG "$@" |
|||
@ -0,0 +1,182 @@ |
|||
@REM ---------------------------------------------------------------------------- |
|||
@REM Licensed to the Apache Software Foundation (ASF) under one |
|||
@REM or more contributor license agreements. See the NOTICE file |
|||
@REM distributed with this work for additional information |
|||
@REM regarding copyright ownership. The ASF licenses this file |
|||
@REM to you under the Apache License, Version 2.0 (the |
|||
@REM "License"); you may not use this file except in compliance |
|||
@REM with the License. You may obtain a copy of the License at |
|||
@REM |
|||
@REM https://www.apache.org/licenses/LICENSE-2.0 |
|||
@REM |
|||
@REM Unless required by applicable law or agreed to in writing, |
|||
@REM software distributed under the License is distributed on an |
|||
@REM "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
|||
@REM KIND, either express or implied. See the License for the |
|||
@REM specific language governing permissions and limitations |
|||
@REM under the License. |
|||
@REM ---------------------------------------------------------------------------- |
|||
|
|||
@REM ---------------------------------------------------------------------------- |
|||
@REM Maven Start Up Batch script |
|||
@REM |
|||
@REM Required ENV vars: |
|||
@REM JAVA_HOME - location of a JDK home dir |
|||
@REM |
|||
@REM Optional ENV vars |
|||
@REM M2_HOME - location of maven2's installed home dir |
|||
@REM MAVEN_BATCH_ECHO - set to 'on' to enable the echoing of the batch commands |
|||
@REM MAVEN_BATCH_PAUSE - set to 'on' to wait for a keystroke before ending |
|||
@REM MAVEN_OPTS - parameters passed to the Java VM when running Maven |
|||
@REM e.g. to debug Maven itself, use |
|||
@REM set MAVEN_OPTS=-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8000 |
|||
@REM MAVEN_SKIP_RC - flag to disable loading of mavenrc files |
|||
@REM ---------------------------------------------------------------------------- |
|||
|
|||
@REM Begin all REM lines with '@' in case MAVEN_BATCH_ECHO is 'on' |
|||
@echo off |
|||
@REM set title of command window |
|||
title %0 |
|||
@REM enable echoing by setting MAVEN_BATCH_ECHO to 'on' |
|||
@if "%MAVEN_BATCH_ECHO%" == "on" echo %MAVEN_BATCH_ECHO% |
|||
|
|||
@REM set %HOME% to equivalent of $HOME |
|||
if "%HOME%" == "" (set "HOME=%HOMEDRIVE%%HOMEPATH%") |
|||
|
|||
@REM Execute a user defined script before this one |
|||
if not "%MAVEN_SKIP_RC%" == "" goto skipRcPre |
|||
@REM check for pre script, once with legacy .bat ending and once with .cmd ending |
|||
if exist "%HOME%\mavenrc_pre.bat" call "%HOME%\mavenrc_pre.bat" |
|||
if exist "%HOME%\mavenrc_pre.cmd" call "%HOME%\mavenrc_pre.cmd" |
|||
:skipRcPre |
|||
|
|||
@setlocal |
|||
|
|||
set ERROR_CODE=0 |
|||
|
|||
@REM To isolate internal variables from possible post scripts, we use another setlocal |
|||
@setlocal |
|||
|
|||
@REM ==== START VALIDATION ==== |
|||
if not "%JAVA_HOME%" == "" goto OkJHome |
|||
|
|||
echo. |
|||
echo Error: JAVA_HOME not found in your environment. >&2 |
|||
echo Please set the JAVA_HOME variable in your environment to match the >&2 |
|||
echo location of your Java installation. >&2 |
|||
echo. |
|||
goto error |
|||
|
|||
:OkJHome |
|||
if exist "%JAVA_HOME%\bin\java.exe" goto init |
|||
|
|||
echo. |
|||
echo Error: JAVA_HOME is set to an invalid directory. >&2 |
|||
echo JAVA_HOME = "%JAVA_HOME%" >&2 |
|||
echo Please set the JAVA_HOME variable in your environment to match the >&2 |
|||
echo location of your Java installation. >&2 |
|||
echo. |
|||
goto error |
|||
|
|||
@REM ==== END VALIDATION ==== |
|||
|
|||
:init |
|||
|
|||
@REM Find the project base dir, i.e. the directory that contains the folder ".mvn". |
|||
@REM Fallback to current working directory if not found. |
|||
|
|||
set MAVEN_PROJECTBASEDIR=%MAVEN_BASEDIR% |
|||
IF NOT "%MAVEN_PROJECTBASEDIR%"=="" goto endDetectBaseDir |
|||
|
|||
set EXEC_DIR=%CD% |
|||
set WDIR=%EXEC_DIR% |
|||
:findBaseDir |
|||
IF EXIST "%WDIR%"\.mvn goto baseDirFound |
|||
cd .. |
|||
IF "%WDIR%"=="%CD%" goto baseDirNotFound |
|||
set WDIR=%CD% |
|||
goto findBaseDir |
|||
|
|||
:baseDirFound |
|||
set MAVEN_PROJECTBASEDIR=%WDIR% |
|||
cd "%EXEC_DIR%" |
|||
goto endDetectBaseDir |
|||
|
|||
:baseDirNotFound |
|||
set MAVEN_PROJECTBASEDIR=%EXEC_DIR% |
|||
cd "%EXEC_DIR%" |
|||
|
|||
:endDetectBaseDir |
|||
|
|||
IF NOT EXIST "%MAVEN_PROJECTBASEDIR%\.mvn\jvm.config" goto endReadAdditionalConfig |
|||
|
|||
@setlocal EnableExtensions EnableDelayedExpansion |
|||
for /F "usebackq delims=" %%a in ("%MAVEN_PROJECTBASEDIR%\.mvn\jvm.config") do set JVM_CONFIG_MAVEN_PROPS=!JVM_CONFIG_MAVEN_PROPS! %%a |
|||
@endlocal & set JVM_CONFIG_MAVEN_PROPS=%JVM_CONFIG_MAVEN_PROPS% |
|||
|
|||
:endReadAdditionalConfig |
|||
|
|||
SET MAVEN_JAVA_EXE="%JAVA_HOME%\bin\java.exe" |
|||
set WRAPPER_JAR="%MAVEN_PROJECTBASEDIR%\.mvn\wrapper\maven-wrapper.jar" |
|||
set WRAPPER_LAUNCHER=org.apache.maven.wrapper.MavenWrapperMain |
|||
|
|||
set DOWNLOAD_URL="https://repo.maven.apache.org/maven2/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar" |
|||
|
|||
FOR /F "tokens=1,2 delims==" %%A IN ("%MAVEN_PROJECTBASEDIR%\.mvn\wrapper\maven-wrapper.properties") DO ( |
|||
IF "%%A"=="wrapperUrl" SET DOWNLOAD_URL=%%B |
|||
) |
|||
|
|||
@REM Extension to allow automatically downloading the maven-wrapper.jar from Maven-central |
|||
@REM This allows using the maven wrapper in projects that prohibit checking in binary data. |
|||
if exist %WRAPPER_JAR% ( |
|||
if "%MVNW_VERBOSE%" == "true" ( |
|||
echo Found %WRAPPER_JAR% |
|||
) |
|||
) else ( |
|||
if not "%MVNW_REPOURL%" == "" ( |
|||
SET DOWNLOAD_URL="%MVNW_REPOURL%/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar" |
|||
) |
|||
if "%MVNW_VERBOSE%" == "true" ( |
|||
echo Couldn't find %WRAPPER_JAR%, downloading it ... |
|||
echo Downloading from: %DOWNLOAD_URL% |
|||
) |
|||
|
|||
powershell -Command "&{"^ |
|||
"$webclient = new-object System.Net.WebClient;"^ |
|||
"if (-not ([string]::IsNullOrEmpty('%MVNW_USERNAME%') -and [string]::IsNullOrEmpty('%MVNW_PASSWORD%'))) {"^ |
|||
"$webclient.Credentials = new-object System.Net.NetworkCredential('%MVNW_USERNAME%', '%MVNW_PASSWORD%');"^ |
|||
"}"^ |
|||
"[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12; $webclient.DownloadFile('%DOWNLOAD_URL%', '%WRAPPER_JAR%')"^ |
|||
"}" |
|||
if "%MVNW_VERBOSE%" == "true" ( |
|||
echo Finished downloading %WRAPPER_JAR% |
|||
) |
|||
) |
|||
@REM End of extension |
|||
|
|||
@REM Provide a "standardized" way to retrieve the CLI args that will |
|||
@REM work with both Windows and non-Windows executions. |
|||
set MAVEN_CMD_LINE_ARGS=%* |
|||
|
|||
%MAVEN_JAVA_EXE% %JVM_CONFIG_MAVEN_PROPS% %MAVEN_OPTS% %MAVEN_DEBUG_OPTS% -classpath %WRAPPER_JAR% "-Dmaven.multiModuleProjectDirectory=%MAVEN_PROJECTBASEDIR%" %WRAPPER_LAUNCHER% %MAVEN_CONFIG% %* |
|||
if ERRORLEVEL 1 goto error |
|||
goto end |
|||
|
|||
:error |
|||
set ERROR_CODE=1 |
|||
|
|||
:end |
|||
@endlocal & set ERROR_CODE=%ERROR_CODE% |
|||
|
|||
if not "%MAVEN_SKIP_RC%" == "" goto skipRcPost |
|||
@REM check for post script, once with legacy .bat ending and once with .cmd ending |
|||
if exist "%HOME%\mavenrc_post.bat" call "%HOME%\mavenrc_post.bat" |
|||
if exist "%HOME%\mavenrc_post.cmd" call "%HOME%\mavenrc_post.cmd" |
|||
:skipRcPost |
|||
|
|||
@REM pause the script if MAVEN_BATCH_PAUSE is set to 'on' |
|||
if "%MAVEN_BATCH_PAUSE%" == "on" pause |
|||
|
|||
if "%MAVEN_TERMINATE_CMD%" == "on" exit %ERROR_CODE% |
|||
|
|||
exit /B %ERROR_CODE% |
|||
@ -0,0 +1,76 @@ |
|||
<?xml version="1.0" encoding="UTF-8"?> |
|||
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" |
|||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd"> |
|||
<modelVersion>4.0.0</modelVersion> |
|||
<parent> |
|||
<groupId>org.springframework.boot</groupId> |
|||
<artifactId>spring-boot-starter-parent</artifactId> |
|||
<version>2.5.4</version> |
|||
<relativePath/> <!-- lookup parent from repository --> |
|||
</parent> |
|||
<groupId>com.example</groupId> |
|||
<artifactId>London</artifactId> |
|||
<version>0.0.1-SNAPSHOT</version> |
|||
<name>London</name> |
|||
<description>Demo project for Spring Boot</description> |
|||
<properties> |
|||
<java.version>1.8</java.version> |
|||
</properties> |
|||
<dependencies> |
|||
<dependency> |
|||
<groupId>org.springframework.boot</groupId> |
|||
<artifactId>spring-boot-starter-data-jpa</artifactId> |
|||
</dependency> |
|||
<dependency> |
|||
<groupId>org.springframework.boot</groupId> |
|||
<artifactId>spring-boot-starter-security</artifactId> |
|||
</dependency> |
|||
<dependency> |
|||
<groupId>org.springframework.boot</groupId> |
|||
<artifactId>spring-boot-starter-web</artifactId> |
|||
</dependency> |
|||
|
|||
<dependency> |
|||
<groupId>org.springframework.boot</groupId> |
|||
<artifactId>spring-boot-devtools</artifactId> |
|||
<scope>runtime</scope> |
|||
<optional>true</optional> |
|||
</dependency> |
|||
<dependency> |
|||
<groupId>mysql</groupId> |
|||
<artifactId>mysql-connector-java</artifactId> |
|||
<scope>runtime</scope> |
|||
</dependency> |
|||
<dependency> |
|||
<groupId>org.springframework.boot</groupId> |
|||
<artifactId>spring-boot-starter-test</artifactId> |
|||
<scope>test</scope> |
|||
</dependency> |
|||
<dependency> |
|||
<groupId>org.springframework.security</groupId> |
|||
<artifactId>spring-security-test</artifactId> |
|||
<scope>test</scope> |
|||
</dependency> |
|||
<dependency> |
|||
<groupId>io.springfox</groupId> |
|||
<artifactId>springfox-swagger2</artifactId> |
|||
<version>2.9.2</version> |
|||
</dependency> |
|||
<dependency> |
|||
<groupId>io.springfox</groupId> |
|||
<artifactId>springfox-swagger-ui</artifactId> |
|||
<version>2.9.2</version> |
|||
</dependency> |
|||
|
|||
</dependencies> |
|||
|
|||
<build> |
|||
<plugins> |
|||
<plugin> |
|||
<groupId>org.springframework.boot</groupId> |
|||
<artifactId>spring-boot-maven-plugin</artifactId> |
|||
</plugin> |
|||
</plugins> |
|||
</build> |
|||
|
|||
</project> |
|||
@ -0,0 +1,10 @@ |
|||
server.port=59274 |
|||
spring.datasource.url=jdbc:mysql://localhost:3306/london_db59274?createDatabaseIfNotExist=true |
|||
server.servlet.context-path=/api |
|||
spring.datasource.username=root |
|||
spring.datasource.password=root |
|||
spring.jpa.hibernate.ddl-auto=update |
|||
spring.jackson.serialization.fail-on-empty-beans=false |
|||
spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.MySQL5Dialect |
|||
spring.jpa.show-sql=false |
|||
spring.jpa.properties.hibernate.format-sql=false |
|||
@ -0,0 +1,310 @@ |
|||
#!/bin/sh |
|||
# ---------------------------------------------------------------------------- |
|||
# Licensed to the Apache Software Foundation (ASF) under one |
|||
# or more contributor license agreements. See the NOTICE file |
|||
# distributed with this work for additional information |
|||
# regarding copyright ownership. The ASF licenses this file |
|||
# to you under the Apache License, Version 2.0 (the |
|||
# "License"); you may not use this file except in compliance |
|||
# with the License. You may obtain a copy of the License at |
|||
# |
|||
# https://www.apache.org/licenses/LICENSE-2.0 |
|||
# |
|||
# Unless required by applicable law or agreed to in writing, |
|||
# software distributed under the License is distributed on an |
|||
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
|||
# KIND, either express or implied. See the License for the |
|||
# specific language governing permissions and limitations |
|||
# under the License. |
|||
# ---------------------------------------------------------------------------- |
|||
|
|||
# ---------------------------------------------------------------------------- |
|||
# Maven Start Up Batch script |
|||
# |
|||
# Required ENV vars: |
|||
# ------------------ |
|||
# JAVA_HOME - location of a JDK home dir |
|||
# |
|||
# Optional ENV vars |
|||
# ----------------- |
|||
# M2_HOME - location of maven2's installed home dir |
|||
# MAVEN_OPTS - parameters passed to the Java VM when running Maven |
|||
# e.g. to debug Maven itself, use |
|||
# set MAVEN_OPTS=-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8000 |
|||
# MAVEN_SKIP_RC - flag to disable loading of mavenrc files |
|||
# ---------------------------------------------------------------------------- |
|||
|
|||
if [ -z "$MAVEN_SKIP_RC" ] ; then |
|||
|
|||
if [ -f /etc/mavenrc ] ; then |
|||
. /etc/mavenrc |
|||
fi |
|||
|
|||
if [ -f "$HOME/.mavenrc" ] ; then |
|||
. "$HOME/.mavenrc" |
|||
fi |
|||
|
|||
fi |
|||
|
|||
# OS specific support. $var _must_ be set to either true or false. |
|||
cygwin=false; |
|||
darwin=false; |
|||
mingw=false |
|||
case "`uname`" in |
|||
CYGWIN*) cygwin=true ;; |
|||
MINGW*) mingw=true;; |
|||
Darwin*) darwin=true |
|||
# Use /usr/libexec/java_home if available, otherwise fall back to /Library/Java/Home |
|||
# See https://developer.apple.com/library/mac/qa/qa1170/_index.html |
|||
if [ -z "$JAVA_HOME" ]; then |
|||
if [ -x "/usr/libexec/java_home" ]; then |
|||
export JAVA_HOME="`/usr/libexec/java_home`" |
|||
else |
|||
export JAVA_HOME="/Library/Java/Home" |
|||
fi |
|||
fi |
|||
;; |
|||
esac |
|||
|
|||
if [ -z "$JAVA_HOME" ] ; then |
|||
if [ -r /etc/gentoo-release ] ; then |
|||
JAVA_HOME=`java-config --jre-home` |
|||
fi |
|||
fi |
|||
|
|||
if [ -z "$M2_HOME" ] ; then |
|||
## resolve links - $0 may be a link to maven's home |
|||
PRG="$0" |
|||
|
|||
# need this for relative symlinks |
|||
while [ -h "$PRG" ] ; do |
|||
ls=`ls -ld "$PRG"` |
|||
link=`expr "$ls" : '.*-> \(.*\)$'` |
|||
if expr "$link" : '/.*' > /dev/null; then |
|||
PRG="$link" |
|||
else |
|||
PRG="`dirname "$PRG"`/$link" |
|||
fi |
|||
done |
|||
|
|||
saveddir=`pwd` |
|||
|
|||
M2_HOME=`dirname "$PRG"`/.. |
|||
|
|||
# make it fully qualified |
|||
M2_HOME=`cd "$M2_HOME" && pwd` |
|||
|
|||
cd "$saveddir" |
|||
# echo Using m2 at $M2_HOME |
|||
fi |
|||
|
|||
# For Cygwin, ensure paths are in UNIX format before anything is touched |
|||
if $cygwin ; then |
|||
[ -n "$M2_HOME" ] && |
|||
M2_HOME=`cygpath --unix "$M2_HOME"` |
|||
[ -n "$JAVA_HOME" ] && |
|||
JAVA_HOME=`cygpath --unix "$JAVA_HOME"` |
|||
[ -n "$CLASSPATH" ] && |
|||
CLASSPATH=`cygpath --path --unix "$CLASSPATH"` |
|||
fi |
|||
|
|||
# For Mingw, ensure paths are in UNIX format before anything is touched |
|||
if $mingw ; then |
|||
[ -n "$M2_HOME" ] && |
|||
M2_HOME="`(cd "$M2_HOME"; pwd)`" |
|||
[ -n "$JAVA_HOME" ] && |
|||
JAVA_HOME="`(cd "$JAVA_HOME"; pwd)`" |
|||
fi |
|||
|
|||
if [ -z "$JAVA_HOME" ]; then |
|||
javaExecutable="`which javac`" |
|||
if [ -n "$javaExecutable" ] && ! [ "`expr \"$javaExecutable\" : '\([^ ]*\)'`" = "no" ]; then |
|||
# readlink(1) is not available as standard on Solaris 10. |
|||
readLink=`which readlink` |
|||
if [ ! `expr "$readLink" : '\([^ ]*\)'` = "no" ]; then |
|||
if $darwin ; then |
|||
javaHome="`dirname \"$javaExecutable\"`" |
|||
javaExecutable="`cd \"$javaHome\" && pwd -P`/javac" |
|||
else |
|||
javaExecutable="`readlink -f \"$javaExecutable\"`" |
|||
fi |
|||
javaHome="`dirname \"$javaExecutable\"`" |
|||
javaHome=`expr "$javaHome" : '\(.*\)/bin'` |
|||
JAVA_HOME="$javaHome" |
|||
export JAVA_HOME |
|||
fi |
|||
fi |
|||
fi |
|||
|
|||
if [ -z "$JAVACMD" ] ; then |
|||
if [ -n "$JAVA_HOME" ] ; then |
|||
if [ -x "$JAVA_HOME/jre/sh/java" ] ; then |
|||
# IBM's JDK on AIX uses strange locations for the executables |
|||
JAVACMD="$JAVA_HOME/jre/sh/java" |
|||
else |
|||
JAVACMD="$JAVA_HOME/bin/java" |
|||
fi |
|||
else |
|||
JAVACMD="`which java`" |
|||
fi |
|||
fi |
|||
|
|||
if [ ! -x "$JAVACMD" ] ; then |
|||
echo "Error: JAVA_HOME is not defined correctly." >&2 |
|||
echo " We cannot execute $JAVACMD" >&2 |
|||
exit 1 |
|||
fi |
|||
|
|||
if [ -z "$JAVA_HOME" ] ; then |
|||
echo "Warning: JAVA_HOME environment variable is not set." |
|||
fi |
|||
|
|||
CLASSWORLDS_LAUNCHER=org.codehaus.plexus.classworlds.launcher.Launcher |
|||
|
|||
# traverses directory structure from process work directory to filesystem root |
|||
# first directory with .mvn subdirectory is considered project base directory |
|||
find_maven_basedir() { |
|||
|
|||
if [ -z "$1" ] |
|||
then |
|||
echo "Path not specified to find_maven_basedir" |
|||
return 1 |
|||
fi |
|||
|
|||
basedir="$1" |
|||
wdir="$1" |
|||
while [ "$wdir" != '/' ] ; do |
|||
if [ -d "$wdir"/.mvn ] ; then |
|||
basedir=$wdir |
|||
break |
|||
fi |
|||
# workaround for JBEAP-8937 (on Solaris 10/Sparc) |
|||
if [ -d "${wdir}" ]; then |
|||
wdir=`cd "$wdir/.."; pwd` |
|||
fi |
|||
# end of workaround |
|||
done |
|||
echo "${basedir}" |
|||
} |
|||
|
|||
# concatenates all lines of a file |
|||
concat_lines() { |
|||
if [ -f "$1" ]; then |
|||
echo "$(tr -s '\n' ' ' < "$1")" |
|||
fi |
|||
} |
|||
|
|||
BASE_DIR=`find_maven_basedir "$(pwd)"` |
|||
if [ -z "$BASE_DIR" ]; then |
|||
exit 1; |
|||
fi |
|||
|
|||
########################################################################################## |
|||
# Extension to allow automatically downloading the maven-wrapper.jar from Maven-central |
|||
# This allows using the maven wrapper in projects that prohibit checking in binary data. |
|||
########################################################################################## |
|||
if [ -r "$BASE_DIR/.mvn/wrapper/maven-wrapper.jar" ]; then |
|||
if [ "$MVNW_VERBOSE" = true ]; then |
|||
echo "Found .mvn/wrapper/maven-wrapper.jar" |
|||
fi |
|||
else |
|||
if [ "$MVNW_VERBOSE" = true ]; then |
|||
echo "Couldn't find .mvn/wrapper/maven-wrapper.jar, downloading it ..." |
|||
fi |
|||
if [ -n "$MVNW_REPOURL" ]; then |
|||
jarUrl="$MVNW_REPOURL/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar" |
|||
else |
|||
jarUrl="https://repo.maven.apache.org/maven2/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar" |
|||
fi |
|||
while IFS="=" read key value; do |
|||
case "$key" in (wrapperUrl) jarUrl="$value"; break ;; |
|||
esac |
|||
done < "$BASE_DIR/.mvn/wrapper/maven-wrapper.properties" |
|||
if [ "$MVNW_VERBOSE" = true ]; then |
|||
echo "Downloading from: $jarUrl" |
|||
fi |
|||
wrapperJarPath="$BASE_DIR/.mvn/wrapper/maven-wrapper.jar" |
|||
if $cygwin; then |
|||
wrapperJarPath=`cygpath --path --windows "$wrapperJarPath"` |
|||
fi |
|||
|
|||
if command -v wget > /dev/null; then |
|||
if [ "$MVNW_VERBOSE" = true ]; then |
|||
echo "Found wget ... using wget" |
|||
fi |
|||
if [ -z "$MVNW_USERNAME" ] || [ -z "$MVNW_PASSWORD" ]; then |
|||
wget "$jarUrl" -O "$wrapperJarPath" |
|||
else |
|||
wget --http-user=$MVNW_USERNAME --http-password=$MVNW_PASSWORD "$jarUrl" -O "$wrapperJarPath" |
|||
fi |
|||
elif command -v curl > /dev/null; then |
|||
if [ "$MVNW_VERBOSE" = true ]; then |
|||
echo "Found curl ... using curl" |
|||
fi |
|||
if [ -z "$MVNW_USERNAME" ] || [ -z "$MVNW_PASSWORD" ]; then |
|||
curl -o "$wrapperJarPath" "$jarUrl" -f |
|||
else |
|||
curl --user $MVNW_USERNAME:$MVNW_PASSWORD -o "$wrapperJarPath" "$jarUrl" -f |
|||
fi |
|||
|
|||
else |
|||
if [ "$MVNW_VERBOSE" = true ]; then |
|||
echo "Falling back to using Java to download" |
|||
fi |
|||
javaClass="$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.java" |
|||
# For Cygwin, switch paths to Windows format before running javac |
|||
if $cygwin; then |
|||
javaClass=`cygpath --path --windows "$javaClass"` |
|||
fi |
|||
if [ -e "$javaClass" ]; then |
|||
if [ ! -e "$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.class" ]; then |
|||
if [ "$MVNW_VERBOSE" = true ]; then |
|||
echo " - Compiling MavenWrapperDownloader.java ..." |
|||
fi |
|||
# Compiling the Java class |
|||
("$JAVA_HOME/bin/javac" "$javaClass") |
|||
fi |
|||
if [ -e "$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.class" ]; then |
|||
# Running the downloader |
|||
if [ "$MVNW_VERBOSE" = true ]; then |
|||
echo " - Running MavenWrapperDownloader.java ..." |
|||
fi |
|||
("$JAVA_HOME/bin/java" -cp .mvn/wrapper MavenWrapperDownloader "$MAVEN_PROJECTBASEDIR") |
|||
fi |
|||
fi |
|||
fi |
|||
fi |
|||
########################################################################################## |
|||
# End of extension |
|||
########################################################################################## |
|||
|
|||
export MAVEN_PROJECTBASEDIR=${MAVEN_BASEDIR:-"$BASE_DIR"} |
|||
if [ "$MVNW_VERBOSE" = true ]; then |
|||
echo $MAVEN_PROJECTBASEDIR |
|||
fi |
|||
MAVEN_OPTS="$(concat_lines "$MAVEN_PROJECTBASEDIR/.mvn/jvm.config") $MAVEN_OPTS" |
|||
|
|||
# For Cygwin, switch paths to Windows format before running java |
|||
if $cygwin; then |
|||
[ -n "$M2_HOME" ] && |
|||
M2_HOME=`cygpath --path --windows "$M2_HOME"` |
|||
[ -n "$JAVA_HOME" ] && |
|||
JAVA_HOME=`cygpath --path --windows "$JAVA_HOME"` |
|||
[ -n "$CLASSPATH" ] && |
|||
CLASSPATH=`cygpath --path --windows "$CLASSPATH"` |
|||
[ -n "$MAVEN_PROJECTBASEDIR" ] && |
|||
MAVEN_PROJECTBASEDIR=`cygpath --path --windows "$MAVEN_PROJECTBASEDIR"` |
|||
fi |
|||
|
|||
# Provide a "standardized" way to retrieve the CLI args that will |
|||
# work with both Windows and non-Windows executions. |
|||
MAVEN_CMD_LINE_ARGS="$MAVEN_CONFIG $@" |
|||
export MAVEN_CMD_LINE_ARGS |
|||
|
|||
WRAPPER_LAUNCHER=org.apache.maven.wrapper.MavenWrapperMain |
|||
|
|||
exec "$JAVACMD" \ |
|||
$MAVEN_OPTS \ |
|||
-classpath "$MAVEN_PROJECTBASEDIR/.mvn/wrapper/maven-wrapper.jar" \ |
|||
"-Dmaven.home=${M2_HOME}" "-Dmaven.multiModuleProjectDirectory=${MAVEN_PROJECTBASEDIR}" \ |
|||
${WRAPPER_LAUNCHER} $MAVEN_CONFIG "$@" |
|||
@ -0,0 +1,182 @@ |
|||
@REM ---------------------------------------------------------------------------- |
|||
@REM Licensed to the Apache Software Foundation (ASF) under one |
|||
@REM or more contributor license agreements. See the NOTICE file |
|||
@REM distributed with this work for additional information |
|||
@REM regarding copyright ownership. The ASF licenses this file |
|||
@REM to you under the Apache License, Version 2.0 (the |
|||
@REM "License"); you may not use this file except in compliance |
|||
@REM with the License. You may obtain a copy of the License at |
|||
@REM |
|||
@REM https://www.apache.org/licenses/LICENSE-2.0 |
|||
@REM |
|||
@REM Unless required by applicable law or agreed to in writing, |
|||
@REM software distributed under the License is distributed on an |
|||
@REM "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
|||
@REM KIND, either express or implied. See the License for the |
|||
@REM specific language governing permissions and limitations |
|||
@REM under the License. |
|||
@REM ---------------------------------------------------------------------------- |
|||
|
|||
@REM ---------------------------------------------------------------------------- |
|||
@REM Maven Start Up Batch script |
|||
@REM |
|||
@REM Required ENV vars: |
|||
@REM JAVA_HOME - location of a JDK home dir |
|||
@REM |
|||
@REM Optional ENV vars |
|||
@REM M2_HOME - location of maven2's installed home dir |
|||
@REM MAVEN_BATCH_ECHO - set to 'on' to enable the echoing of the batch commands |
|||
@REM MAVEN_BATCH_PAUSE - set to 'on' to wait for a keystroke before ending |
|||
@REM MAVEN_OPTS - parameters passed to the Java VM when running Maven |
|||
@REM e.g. to debug Maven itself, use |
|||
@REM set MAVEN_OPTS=-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8000 |
|||
@REM MAVEN_SKIP_RC - flag to disable loading of mavenrc files |
|||
@REM ---------------------------------------------------------------------------- |
|||
|
|||
@REM Begin all REM lines with '@' in case MAVEN_BATCH_ECHO is 'on' |
|||
@echo off |
|||
@REM set title of command window |
|||
title %0 |
|||
@REM enable echoing by setting MAVEN_BATCH_ECHO to 'on' |
|||
@if "%MAVEN_BATCH_ECHO%" == "on" echo %MAVEN_BATCH_ECHO% |
|||
|
|||
@REM set %HOME% to equivalent of $HOME |
|||
if "%HOME%" == "" (set "HOME=%HOMEDRIVE%%HOMEPATH%") |
|||
|
|||
@REM Execute a user defined script before this one |
|||
if not "%MAVEN_SKIP_RC%" == "" goto skipRcPre |
|||
@REM check for pre script, once with legacy .bat ending and once with .cmd ending |
|||
if exist "%HOME%\mavenrc_pre.bat" call "%HOME%\mavenrc_pre.bat" |
|||
if exist "%HOME%\mavenrc_pre.cmd" call "%HOME%\mavenrc_pre.cmd" |
|||
:skipRcPre |
|||
|
|||
@setlocal |
|||
|
|||
set ERROR_CODE=0 |
|||
|
|||
@REM To isolate internal variables from possible post scripts, we use another setlocal |
|||
@setlocal |
|||
|
|||
@REM ==== START VALIDATION ==== |
|||
if not "%JAVA_HOME%" == "" goto OkJHome |
|||
|
|||
echo. |
|||
echo Error: JAVA_HOME not found in your environment. >&2 |
|||
echo Please set the JAVA_HOME variable in your environment to match the >&2 |
|||
echo location of your Java installation. >&2 |
|||
echo. |
|||
goto error |
|||
|
|||
:OkJHome |
|||
if exist "%JAVA_HOME%\bin\java.exe" goto init |
|||
|
|||
echo. |
|||
echo Error: JAVA_HOME is set to an invalid directory. >&2 |
|||
echo JAVA_HOME = "%JAVA_HOME%" >&2 |
|||
echo Please set the JAVA_HOME variable in your environment to match the >&2 |
|||
echo location of your Java installation. >&2 |
|||
echo. |
|||
goto error |
|||
|
|||
@REM ==== END VALIDATION ==== |
|||
|
|||
:init |
|||
|
|||
@REM Find the project base dir, i.e. the directory that contains the folder ".mvn". |
|||
@REM Fallback to current working directory if not found. |
|||
|
|||
set MAVEN_PROJECTBASEDIR=%MAVEN_BASEDIR% |
|||
IF NOT "%MAVEN_PROJECTBASEDIR%"=="" goto endDetectBaseDir |
|||
|
|||
set EXEC_DIR=%CD% |
|||
set WDIR=%EXEC_DIR% |
|||
:findBaseDir |
|||
IF EXIST "%WDIR%"\.mvn goto baseDirFound |
|||
cd .. |
|||
IF "%WDIR%"=="%CD%" goto baseDirNotFound |
|||
set WDIR=%CD% |
|||
goto findBaseDir |
|||
|
|||
:baseDirFound |
|||
set MAVEN_PROJECTBASEDIR=%WDIR% |
|||
cd "%EXEC_DIR%" |
|||
goto endDetectBaseDir |
|||
|
|||
:baseDirNotFound |
|||
set MAVEN_PROJECTBASEDIR=%EXEC_DIR% |
|||
cd "%EXEC_DIR%" |
|||
|
|||
:endDetectBaseDir |
|||
|
|||
IF NOT EXIST "%MAVEN_PROJECTBASEDIR%\.mvn\jvm.config" goto endReadAdditionalConfig |
|||
|
|||
@setlocal EnableExtensions EnableDelayedExpansion |
|||
for /F "usebackq delims=" %%a in ("%MAVEN_PROJECTBASEDIR%\.mvn\jvm.config") do set JVM_CONFIG_MAVEN_PROPS=!JVM_CONFIG_MAVEN_PROPS! %%a |
|||
@endlocal & set JVM_CONFIG_MAVEN_PROPS=%JVM_CONFIG_MAVEN_PROPS% |
|||
|
|||
:endReadAdditionalConfig |
|||
|
|||
SET MAVEN_JAVA_EXE="%JAVA_HOME%\bin\java.exe" |
|||
set WRAPPER_JAR="%MAVEN_PROJECTBASEDIR%\.mvn\wrapper\maven-wrapper.jar" |
|||
set WRAPPER_LAUNCHER=org.apache.maven.wrapper.MavenWrapperMain |
|||
|
|||
set DOWNLOAD_URL="https://repo.maven.apache.org/maven2/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar" |
|||
|
|||
FOR /F "tokens=1,2 delims==" %%A IN ("%MAVEN_PROJECTBASEDIR%\.mvn\wrapper\maven-wrapper.properties") DO ( |
|||
IF "%%A"=="wrapperUrl" SET DOWNLOAD_URL=%%B |
|||
) |
|||
|
|||
@REM Extension to allow automatically downloading the maven-wrapper.jar from Maven-central |
|||
@REM This allows using the maven wrapper in projects that prohibit checking in binary data. |
|||
if exist %WRAPPER_JAR% ( |
|||
if "%MVNW_VERBOSE%" == "true" ( |
|||
echo Found %WRAPPER_JAR% |
|||
) |
|||
) else ( |
|||
if not "%MVNW_REPOURL%" == "" ( |
|||
SET DOWNLOAD_URL="%MVNW_REPOURL%/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar" |
|||
) |
|||
if "%MVNW_VERBOSE%" == "true" ( |
|||
echo Couldn't find %WRAPPER_JAR%, downloading it ... |
|||
echo Downloading from: %DOWNLOAD_URL% |
|||
) |
|||
|
|||
powershell -Command "&{"^ |
|||
"$webclient = new-object System.Net.WebClient;"^ |
|||
"if (-not ([string]::IsNullOrEmpty('%MVNW_USERNAME%') -and [string]::IsNullOrEmpty('%MVNW_PASSWORD%'))) {"^ |
|||
"$webclient.Credentials = new-object System.Net.NetworkCredential('%MVNW_USERNAME%', '%MVNW_PASSWORD%');"^ |
|||
"}"^ |
|||
"[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12; $webclient.DownloadFile('%DOWNLOAD_URL%', '%WRAPPER_JAR%')"^ |
|||
"}" |
|||
if "%MVNW_VERBOSE%" == "true" ( |
|||
echo Finished downloading %WRAPPER_JAR% |
|||
) |
|||
) |
|||
@REM End of extension |
|||
|
|||
@REM Provide a "standardized" way to retrieve the CLI args that will |
|||
@REM work with both Windows and non-Windows executions. |
|||
set MAVEN_CMD_LINE_ARGS=%* |
|||
|
|||
%MAVEN_JAVA_EXE% %JVM_CONFIG_MAVEN_PROPS% %MAVEN_OPTS% %MAVEN_DEBUG_OPTS% -classpath %WRAPPER_JAR% "-Dmaven.multiModuleProjectDirectory=%MAVEN_PROJECTBASEDIR%" %WRAPPER_LAUNCHER% %MAVEN_CONFIG% %* |
|||
if ERRORLEVEL 1 goto error |
|||
goto end |
|||
|
|||
:error |
|||
set ERROR_CODE=1 |
|||
|
|||
:end |
|||
@endlocal & set ERROR_CODE=%ERROR_CODE% |
|||
|
|||
if not "%MAVEN_SKIP_RC%" == "" goto skipRcPost |
|||
@REM check for post script, once with legacy .bat ending and once with .cmd ending |
|||
if exist "%HOME%\mavenrc_post.bat" call "%HOME%\mavenrc_post.bat" |
|||
if exist "%HOME%\mavenrc_post.cmd" call "%HOME%\mavenrc_post.cmd" |
|||
:skipRcPost |
|||
|
|||
@REM pause the script if MAVEN_BATCH_PAUSE is set to 'on' |
|||
if "%MAVEN_BATCH_PAUSE%" == "on" pause |
|||
|
|||
if "%MAVEN_TERMINATE_CMD%" == "on" exit %ERROR_CODE% |
|||
|
|||
exit /B %ERROR_CODE% |
|||
@ -0,0 +1,76 @@ |
|||
<?xml version="1.0" encoding="UTF-8"?> |
|||
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" |
|||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd"> |
|||
<modelVersion>4.0.0</modelVersion> |
|||
<parent> |
|||
<groupId>org.springframework.boot</groupId> |
|||
<artifactId>spring-boot-starter-parent</artifactId> |
|||
<version>2.5.4</version> |
|||
<relativePath/> <!-- lookup parent from repository --> |
|||
</parent> |
|||
<groupId>com.example</groupId> |
|||
<artifactId>London</artifactId> |
|||
<version>0.0.1-SNAPSHOT</version> |
|||
<name>London</name> |
|||
<description>Demo project for Spring Boot</description> |
|||
<properties> |
|||
<java.version>1.8</java.version> |
|||
</properties> |
|||
<dependencies> |
|||
<dependency> |
|||
<groupId>org.springframework.boot</groupId> |
|||
<artifactId>spring-boot-starter-data-jpa</artifactId> |
|||
</dependency> |
|||
<dependency> |
|||
<groupId>org.springframework.boot</groupId> |
|||
<artifactId>spring-boot-starter-security</artifactId> |
|||
</dependency> |
|||
<dependency> |
|||
<groupId>org.springframework.boot</groupId> |
|||
<artifactId>spring-boot-starter-web</artifactId> |
|||
</dependency> |
|||
|
|||
<dependency> |
|||
<groupId>org.springframework.boot</groupId> |
|||
<artifactId>spring-boot-devtools</artifactId> |
|||
<scope>runtime</scope> |
|||
<optional>true</optional> |
|||
</dependency> |
|||
<dependency> |
|||
<groupId>mysql</groupId> |
|||
<artifactId>mysql-connector-java</artifactId> |
|||
<scope>runtime</scope> |
|||
</dependency> |
|||
<dependency> |
|||
<groupId>org.springframework.boot</groupId> |
|||
<artifactId>spring-boot-starter-test</artifactId> |
|||
<scope>test</scope> |
|||
</dependency> |
|||
<dependency> |
|||
<groupId>org.springframework.security</groupId> |
|||
<artifactId>spring-security-test</artifactId> |
|||
<scope>test</scope> |
|||
</dependency> |
|||
<dependency> |
|||
<groupId>io.springfox</groupId> |
|||
<artifactId>springfox-swagger2</artifactId> |
|||
<version>2.9.2</version> |
|||
</dependency> |
|||
<dependency> |
|||
<groupId>io.springfox</groupId> |
|||
<artifactId>springfox-swagger-ui</artifactId> |
|||
<version>2.9.2</version> |
|||
</dependency> |
|||
|
|||
</dependencies> |
|||
|
|||
<build> |
|||
<plugins> |
|||
<plugin> |
|||
<groupId>org.springframework.boot</groupId> |
|||
<artifactId>spring-boot-maven-plugin</artifactId> |
|||
</plugin> |
|||
</plugins> |
|||
</build> |
|||
|
|||
</project> |
|||
@ -0,0 +1,14 @@ |
|||
package com.example.londonStore; |
|||
import org.springframework.context.annotation.Configuration; |
|||
import org.springframework.web.servlet.config.annotation.CorsRegistry; |
|||
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer; |
|||
@Configuration |
|||
public class CorsConfig implements WebMvcConfigurer{ |
|||
@Override |
|||
public void addCorsMappings(CorsRegistry registry) { |
|||
// TODO Auto-generated method stub |
|||
WebMvcConfigurer.super.addCorsMappings(registry); |
|||
registry.addMapping("/**"); |
|||
|
|||
} |
|||
} |
|||
@ -0,0 +1,31 @@ |
|||
package com.example.londonStore; |
|||
|
|||
import org.springframework.boot.SpringApplication; |
|||
import org.springframework.boot.autoconfigure.SpringBootApplication; |
|||
import org.springframework.context.annotation.Bean; |
|||
|
|||
import springfox.documentation.builders.ApiInfoBuilder; |
|||
import springfox.documentation.service.ApiInfo; |
|||
import springfox.documentation.spi.DocumentationType; |
|||
import springfox.documentation.spring.web.plugins.Docket; |
|||
import springfox.documentation.swagger2.annotations.EnableSwagger2; |
|||
|
|||
@SpringBootApplication |
|||
@EnableSwagger2 |
|||
//@EnableAutoConfiguration(exclude= {SecurityAutoConfiguration.class}) |
|||
public class LondonApplication { |
|||
|
|||
public static void main(String[] args) { |
|||
SpringApplication.run(LondonApplication.class, args); |
|||
} |
|||
@Bean |
|||
public Docket postsApi() { |
|||
return new Docket(DocumentationType.SWAGGER_2) |
|||
.apiInfo(apiInfo()).select().build(); |
|||
} |
|||
private ApiInfo apiInfo() { |
|||
return new ApiInfoBuilder().title("London Store") |
|||
.description("London") .termsOfServiceUrl("https://simplifyingtech371899608.wordpress.com/") .licenseUrl("simplifyingtech@gmail.com").version("2.0").build(); |
|||
} |
|||
|
|||
} |
|||
@ -0,0 +1,56 @@ |
|||
package com.example.londonStore; |
|||
|
|||
import org.springframework.beans.factory.annotation.Autowired; |
|||
import org.springframework.context.annotation.Bean; |
|||
import org.springframework.context.annotation.Configuration; |
|||
import org.springframework.context.annotation.Primary; |
|||
import org.springframework.security.authentication.dao.DaoAuthenticationProvider; |
|||
import org.springframework.security.config.annotation.authentication.builders.AuthenticationManagerBuilder; |
|||
import org.springframework.security.config.annotation.web.builders.HttpSecurity; |
|||
import org.springframework.security.config.annotation.web.configuration.EnableWebSecurity; |
|||
import org.springframework.security.config.annotation.web.configuration.WebSecurityConfigurerAdapter; |
|||
import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder; |
|||
import org.springframework.security.crypto.password.PasswordEncoder; |
|||
import com.example.londonStore.service.MyUserDetailsService; |
|||
|
|||
|
|||
@Configuration |
|||
@EnableWebSecurity |
|||
public class SecurityConfig extends WebSecurityConfigurerAdapter{ |
|||
@Autowired |
|||
private MyUserDetailsService myUserDetailsService; |
|||
@Override |
|||
protected void configure(HttpSecurity http) throws Exception { |
|||
System.out.println("hi"); |
|||
http.authorizeRequests() |
|||
.antMatchers("/customer").authenticated() |
|||
.antMatchers("/vendor").hasAnyAuthority("ADMIN") |
|||
.antMatchers("/product/**").permitAll() |
|||
.antMatchers("/review/**").permitAll() |
|||
.antMatchers("/login").permitAll() |
|||
.antMatchers("/user").permitAll() |
|||
.and() |
|||
.httpBasic(); |
|||
http.cors(); |
|||
http.csrf().disable(); //cross-site req forgery |
|||
} |
|||
@Override |
|||
protected void configure(AuthenticationManagerBuilder auth) throws Exception { |
|||
auth.authenticationProvider(getAuthenticator()); |
|||
} |
|||
|
|||
private DaoAuthenticationProvider getAuthenticator() { |
|||
// TODO Auto-generated method stub |
|||
DaoAuthenticationProvider dao=new DaoAuthenticationProvider(); |
|||
dao.setUserDetailsService(myUserDetailsService); |
|||
dao.setPasswordEncoder(getPasswordEncoder()); |
|||
return dao; |
|||
} |
|||
@Primary |
|||
@Bean |
|||
public PasswordEncoder getPasswordEncoder() { |
|||
// TODO Auto-generated method stub |
|||
return new BCryptPasswordEncoder(); |
|||
} |
|||
|
|||
} |
|||
@ -0,0 +1,30 @@ |
|||
package com.example.londonStore.controller; |
|||
|
|||
import java.util.List; |
|||
|
|||
import org.springframework.beans.factory.annotation.Autowired; |
|||
import org.springframework.web.bind.annotation.GetMapping; |
|||
import org.springframework.web.bind.annotation.PathVariable; |
|||
import org.springframework.web.bind.annotation.PostMapping; |
|||
import org.springframework.web.bind.annotation.RequestBody; |
|||
import org.springframework.web.bind.annotation.RestController; |
|||
import com.example.londonStore.model.Category; |
|||
import com.example.londonStore.service.Home; |
|||
@RestController |
|||
public class HomeController { |
|||
@Autowired |
|||
private Home home; |
|||
@GetMapping("/category") |
|||
public List<Category> getAll() { |
|||
return home.get(); |
|||
} |
|||
@PostMapping("/category") |
|||
public Category insert(@RequestBody Category category) { |
|||
return home.insert(category); |
|||
} |
|||
@GetMapping("/category/{name}") |
|||
public Category getOne(@PathVariable("name") String name) { |
|||
return home.getOne(name); |
|||
} |
|||
|
|||
} |
|||
@ -0,0 +1,76 @@ |
|||
package com.example.londonStore.controller; |
|||
|
|||
import java.security.Principal; |
|||
import java.util.Base64; |
|||
import java.util.*; |
|||
import org.springframework.beans.factory.annotation.Autowired; |
|||
import org.springframework.http.ResponseEntity; |
|||
import org.springframework.security.crypto.password.PasswordEncoder; |
|||
import org.springframework.web.bind.annotation.CrossOrigin; |
|||
import org.springframework.web.bind.annotation.GetMapping; |
|||
import org.springframework.web.bind.annotation.PathVariable; |
|||
import org.springframework.web.bind.annotation.PostMapping; |
|||
import org.springframework.web.bind.annotation.PutMapping; |
|||
import org.springframework.web.bind.annotation.RequestBody; |
|||
import org.springframework.web.bind.annotation.RequestMethod; |
|||
import org.springframework.web.bind.annotation.RestController; |
|||
|
|||
import com.example.londonStore.model.User; |
|||
import com.example.londonStore.repository.UserRepository; |
|||
|
|||
|
|||
|
|||
@RestController |
|||
@CrossOrigin(origins="http://localhost:4200",methods = {RequestMethod.DELETE,RequestMethod.GET,RequestMethod.POST,RequestMethod.PUT}) |
|||
|
|||
public class UserController { |
|||
@Autowired |
|||
private UserRepository userRepo; |
|||
@Autowired |
|||
private PasswordEncoder passEncoder; |
|||
@GetMapping("/user/{name}") |
|||
private User getDetails(@PathVariable("name") String name) { |
|||
return userRepo.getByUserName(name); |
|||
} |
|||
@PutMapping("user/{name}") |
|||
private User putUser(@PathVariable("name") String name,@RequestBody User user) { |
|||
User us=userRepo.getByUserName(name); |
|||
User use=userRepo.getById(us.getId()); |
|||
use.setName(user.getName()); |
|||
use.setMobile(user.getMobile()); |
|||
use.setEmail(user.getEmail()); |
|||
use.setAddress(user.getAddress()); |
|||
String enPass=passEncoder.encode(user.getPassword()); |
|||
use.setPassword(enPass); |
|||
return userRepo.save(use); |
|||
|
|||
} |
|||
@PostMapping("/user") |
|||
private ResponseEntity<Object> postUser(@RequestBody User user) { |
|||
String op= userRepo.getByUserName(user.getUsername()).getUsername(); |
|||
if(!op.isEmpty()) { |
|||
return ResponseEntity.badRequest().body("The user is already Present, Failed to Create new User"); |
|||
} |
|||
else { |
|||
String code=user.getUsername(); |
|||
String username=new String(Base64.getDecoder().decode(code)).split(":")[0]; |
|||
String password=new String(Base64.getDecoder().decode(code)).split(":")[1]; |
|||
user.setUsername(username); |
|||
user.setPassword(password); |
|||
System.out.println(username+":"+password); |
|||
String enPass=passEncoder.encode(user.getPassword()); |
|||
user.setPassword(enPass); |
|||
return ResponseEntity.ok("User Created Successfully"); |
|||
} |
|||
|
|||
} |
|||
@GetMapping("/login") |
|||
private Principal getUser(Principal principal) { |
|||
System.out.println("Yes"); |
|||
if(principal.getName()==null) { |
|||
throw new Error("Invalid Credentials"); |
|||
} |
|||
System.out.println(principal); |
|||
return principal; |
|||
} |
|||
} |
|||
@ -0,0 +1,27 @@ |
|||
package com.example.londonStore.model; |
|||
|
|||
import javax.persistence.Entity; |
|||
import javax.persistence.GeneratedValue; |
|||
import javax.persistence.GenerationType; |
|||
import javax.persistence.Id; |
|||
|
|||
@Entity |
|||
public class Category { |
|||
@Id |
|||
@GeneratedValue(strategy = GenerationType.AUTO) |
|||
private Long Id; |
|||
public Long getId() { |
|||
return Id; |
|||
} |
|||
public void setId(Long id) { |
|||
Id = id; |
|||
} |
|||
private String category; |
|||
public String getCategory() { |
|||
return category; |
|||
} |
|||
public void setCategory(String category) { |
|||
this.category= category; |
|||
} |
|||
|
|||
} |
|||
@ -0,0 +1,111 @@ |
|||
package com.example.londonStore.model; |
|||
|
|||
import java.util.ArrayList; |
|||
import java.util.Collection; |
|||
import java.util.List; |
|||
|
|||
import javax.persistence.Column; |
|||
import javax.persistence.Entity; |
|||
import javax.persistence.GeneratedValue; |
|||
import javax.persistence.GenerationType; |
|||
import javax.persistence.Id; |
|||
import javax.persistence.Table; |
|||
import javax.persistence.UniqueConstraint; |
|||
|
|||
import org.springframework.security.core.GrantedAuthority; |
|||
import org.springframework.security.core.authority.SimpleGrantedAuthority; |
|||
import org.springframework.security.core.userdetails.UserDetails; |
|||
|
|||
@Entity |
|||
@Table(uniqueConstraints={@UniqueConstraint(columnNames={"username"})}) |
|||
public class User implements UserDetails{ |
|||
/** |
|||
* |
|||
*/ |
|||
private static final long serialVersionUID = 1L; |
|||
@Id |
|||
@GeneratedValue(strategy = GenerationType.AUTO) |
|||
private Long Id; |
|||
private String name; |
|||
public String getName() { |
|||
return name; |
|||
} |
|||
public void setName(String name) { |
|||
this.name = name; |
|||
} |
|||
public Long getMobile() { |
|||
return mobile; |
|||
} |
|||
public void setMobile(Long mobile) { |
|||
this.mobile = mobile; |
|||
} |
|||
@Column(unique = true) |
|||
private String username; |
|||
@Column(unique = true) |
|||
private String email; |
|||
private String password; |
|||
private String address; |
|||
private Long mobile; |
|||
public String getEmail() { |
|||
return email; |
|||
} |
|||
public void setEmail(String email) { |
|||
this.email = email; |
|||
} |
|||
public String getAddress() { |
|||
return address; |
|||
} |
|||
public void setAddress(String address) { |
|||
this.address = address; |
|||
} |
|||
|
|||
public Long getId() { |
|||
return Id; |
|||
} |
|||
public void setId(Long id) { |
|||
Id = id; |
|||
} |
|||
|
|||
|
|||
public String getUsername() { |
|||
return username; |
|||
} |
|||
public void setUsername(String username) { |
|||
this.username = username; |
|||
} |
|||
public String getPassword() { |
|||
return password; |
|||
} |
|||
public void setPassword(String password) { |
|||
this.password = password; |
|||
} |
|||
|
|||
@Override |
|||
public Collection<? extends GrantedAuthority> getAuthorities() { |
|||
// TODO Auto-generated method stub |
|||
List<GrantedAuthority> list=new ArrayList<>(); |
|||
SimpleGrantedAuthority sga=new SimpleGrantedAuthority("CUSTOMER"); |
|||
list.add(sga); |
|||
return list; |
|||
} |
|||
@Override |
|||
public boolean isAccountNonExpired() { |
|||
// TODO Auto-generated method stub |
|||
return true; |
|||
} |
|||
@Override |
|||
public boolean isAccountNonLocked() { |
|||
// TODO Auto-generated method stub |
|||
return true; |
|||
} |
|||
@Override |
|||
public boolean isCredentialsNonExpired() { |
|||
// TODO Auto-generated method stub |
|||
return true; |
|||
} |
|||
@Override |
|||
public boolean isEnabled() { |
|||
// TODO Auto-generated method stub |
|||
return true; |
|||
} |
|||
} |
|||
@ -0,0 +1,11 @@ |
|||
package com.example.londonStore.repository; |
|||
|
|||
import org.springframework.data.jpa.repository.JpaRepository; |
|||
|
|||
import com.example.londonStore.model.Category; |
|||
|
|||
public interface CategoryRepo extends JpaRepository<Category, Long>{ |
|||
|
|||
Category getByCategory(String name); |
|||
|
|||
} |
|||
@ -0,0 +1,14 @@ |
|||
package com.example.londonStore.repository; |
|||
|
|||
import org.springframework.data.jpa.repository.JpaRepository; |
|||
import org.springframework.data.jpa.repository.Query; |
|||
|
|||
import com.example.londonStore.model.User; |
|||
|
|||
|
|||
public interface UserRepository extends JpaRepository<User, Long> { |
|||
@Query("select u from User u where u.username=?1") |
|||
User getByUserName(String username); |
|||
|
|||
|
|||
} |
|||
@ -0,0 +1,27 @@ |
|||
package com.example.londonStore.service; |
|||
|
|||
import java.util.List; |
|||
|
|||
import org.springframework.beans.factory.annotation.Autowired; |
|||
import org.springframework.stereotype.Service; |
|||
import com.example.londonStore.model.Category; |
|||
import com.example.londonStore.repository.CategoryRepo; |
|||
|
|||
@Service |
|||
public class Home { |
|||
@Autowired |
|||
private CategoryRepo categoryRepo; |
|||
public List<Category> get(){ |
|||
List<Category> li=categoryRepo.findAll(); |
|||
return li; |
|||
} |
|||
|
|||
public Category getOne(String name) { |
|||
return categoryRepo.getByCategory(name); |
|||
} |
|||
|
|||
public Category insert(Category category) { |
|||
return categoryRepo.save(category); |
|||
} |
|||
|
|||
} |
|||
@ -0,0 +1,25 @@ |
|||
package com.example.londonStore.service; |
|||
|
|||
import org.springframework.beans.factory.annotation.Autowired; |
|||
import org.springframework.security.core.userdetails.UserDetails; |
|||
import org.springframework.security.core.userdetails.UserDetailsService; |
|||
import org.springframework.security.core.userdetails.UsernameNotFoundException; |
|||
import org.springframework.stereotype.Service; |
|||
|
|||
import com.example.londonStore.model.User; |
|||
import com.example.londonStore.repository.UserRepository; |
|||
|
|||
|
|||
|
|||
@Service |
|||
public class MyUserDetailsService implements UserDetailsService{ |
|||
@Autowired |
|||
private UserRepository userRepo; |
|||
@Override |
|||
public UserDetails loadUserByUsername(String username) throws UsernameNotFoundException { |
|||
// TODO Auto-generated method stub |
|||
User user=userRepo.getByUserName(username); |
|||
return user; |
|||
} |
|||
|
|||
} |
|||
@ -0,0 +1,10 @@ |
|||
server.port=59274 |
|||
spring.datasource.url=jdbc:mysql://localhost:3306/LondonStoreDB?createDatabaseIfNotExist=true |
|||
server.servlet.context-path=/apiUser |
|||
spring.datasource.username=root |
|||
spring.datasource.password=Password123 |
|||
spring.jpa.hibernate.ddl-auto=update |
|||
spring.jackson.serialization.fail-on-empty-beans=false |
|||
spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.MySQL5Dialect |
|||
spring.jpa.show-sql=false |
|||
spring.jpa.properties.hibernate.format-sql=false |
|||
@ -0,0 +1,13 @@ |
|||
package com.example.londonStore; |
|||
|
|||
import org.junit.jupiter.api.Test; |
|||
import org.springframework.boot.test.context.SpringBootTest; |
|||
|
|||
@SpringBootTest |
|||
class LondonApplicationTests { |
|||
|
|||
@Test |
|||
void contextLoads() { |
|||
} |
|||
|
|||
} |
|||
@ -0,0 +1,17 @@ |
|||
# This file is used by the build system to adjust CSS and JS output to support the specified browsers below. |
|||
# For additional information regarding the format and rule options, please see: |
|||
# https://github.com/browserslist/browserslist#queries |
|||
|
|||
# For the full list of supported browsers by the Angular framework, please see: |
|||
# https://angular.io/guide/browser-support |
|||
|
|||
# You can see what browsers were selected by your queries by running: |
|||
# npx browserslist |
|||
|
|||
last 1 Chrome version |
|||
last 1 Firefox version |
|||
last 2 Edge major versions |
|||
last 2 Safari major versions |
|||
last 2 iOS major versions |
|||
Firefox ESR |
|||
not IE 11 # Angular supports IE 11 only as an opt-in. To opt-in, remove the 'not' prefix on this line. |
|||
@ -0,0 +1,16 @@ |
|||
# Editor configuration, see https://editorconfig.org |
|||
root = true |
|||
|
|||
[*] |
|||
charset = utf-8 |
|||
indent_style = space |
|||
indent_size = 2 |
|||
insert_final_newline = true |
|||
trim_trailing_whitespace = true |
|||
|
|||
[*.ts] |
|||
quote_type = single |
|||
|
|||
[*.md] |
|||
max_line_length = off |
|||
trim_trailing_whitespace = false |
|||
@ -0,0 +1,45 @@ |
|||
# See http://help.github.com/ignore-files/ for more about ignoring files. |
|||
|
|||
# compiled output |
|||
/dist |
|||
/tmp |
|||
/out-tsc |
|||
# Only exists if Bazel was run |
|||
/bazel-out |
|||
|
|||
# dependencies |
|||
/node_modules |
|||
|
|||
# profiling files |
|||
chrome-profiler-events*.json |
|||
|
|||
# IDEs and editors |
|||
/.idea |
|||
.project |
|||
.classpath |
|||
.c9/ |
|||
*.launch |
|||
.settings/ |
|||
*.sublime-workspace |
|||
|
|||
# IDE - VSCode |
|||
.vscode/* |
|||
!.vscode/settings.json |
|||
!.vscode/tasks.json |
|||
!.vscode/launch.json |
|||
!.vscode/extensions.json |
|||
.history/* |
|||
|
|||
# misc |
|||
/.sass-cache |
|||
/connect.lock |
|||
/coverage |
|||
/libpeerconnection.log |
|||
npm-debug.log |
|||
yarn-error.log |
|||
testem.log |
|||
/typings |
|||
|
|||
# System Files |
|||
.DS_Store |
|||
Thumbs.db |
|||
@ -0,0 +1,27 @@ |
|||
# Prod |
|||
|
|||
This project was generated with [Angular CLI](https://github.com/angular/angular-cli) version 12.1.1. |
|||
|
|||
## Development server |
|||
|
|||
Run `ng serve` for a dev server. Navigate to `http://localhost:4200/`. The app will automatically reload if you change any of the source files. |
|||
|
|||
## Code scaffolding |
|||
|
|||
Run `ng generate component component-name` to generate a new component. You can also use `ng generate directive|pipe|service|class|guard|interface|enum|module`. |
|||
|
|||
## Build |
|||
|
|||
Run `ng build` to build the project. The build artifacts will be stored in the `dist/` directory. |
|||
|
|||
## Running unit tests |
|||
|
|||
Run `ng test` to execute the unit tests via [Karma](https://karma-runner.github.io). |
|||
|
|||
## Running end-to-end tests |
|||
|
|||
Run `ng e2e` to execute the end-to-end tests via a platform of your choice. To use this command, you need to first add a package that implements end-to-end testing capabilities. |
|||
|
|||
## Further help |
|||
|
|||
To get more help on the Angular CLI use `ng help` or go check out the [Angular CLI Overview and Command Reference](https://angular.io/cli) page. |
|||
@ -0,0 +1,110 @@ |
|||
{ |
|||
"$schema": "./node_modules/@angular/cli/lib/config/schema.json", |
|||
"version": 1, |
|||
"newProjectRoot": "projects", |
|||
"projects": { |
|||
"prod": { |
|||
"projectType": "application", |
|||
"schematics": { |
|||
"@schematics/angular:application": { |
|||
"strict": true |
|||
} |
|||
}, |
|||
"root": "", |
|||
"sourceRoot": "src", |
|||
"prefix": "app", |
|||
"architect": { |
|||
"build": { |
|||
"builder": "@angular-devkit/build-angular:browser", |
|||
"options": { |
|||
"outputPath": "dist/prod", |
|||
"index": "src/index.html", |
|||
"main": "src/main.ts", |
|||
"polyfills": "src/polyfills.ts", |
|||
"tsConfig": "tsconfig.app.json", |
|||
"assets": [ |
|||
"src/favicon.ico", |
|||
"src/assets" |
|||
], |
|||
"styles": [ |
|||
"src/styles.css" |
|||
], |
|||
"scripts": [] |
|||
}, |
|||
"configurations": { |
|||
"production": { |
|||
"budgets": [ |
|||
{ |
|||
"type": "initial", |
|||
"maximumWarning": "500kb", |
|||
"maximumError": "1mb" |
|||
}, |
|||
{ |
|||
"type": "anyComponentStyle", |
|||
"maximumWarning": "2kb", |
|||
"maximumError": "4kb" |
|||
} |
|||
], |
|||
"fileReplacements": [ |
|||
{ |
|||
"replace": "src/environments/environment.ts", |
|||
"with": "src/environments/environment.prod.ts" |
|||
} |
|||
], |
|||
"outputHashing": "all" |
|||
}, |
|||
"development": { |
|||
"buildOptimizer": false, |
|||
"optimization": false, |
|||
"vendorChunk": true, |
|||
"extractLicenses": false, |
|||
"sourceMap": true, |
|||
"namedChunks": true |
|||
} |
|||
}, |
|||
"defaultConfiguration": "production" |
|||
}, |
|||
"serve": { |
|||
"options": { |
|||
"host": "0.0.0.0", |
|||
"port": 4300 |
|||
}, |
|||
"builder": "@angular-devkit/build-angular:dev-server", |
|||
"configurations": { |
|||
"production": { |
|||
"browserTarget": "prod:build:production" |
|||
}, |
|||
"development": { |
|||
"browserTarget": "prod:build:development" |
|||
} |
|||
}, |
|||
"defaultConfiguration": "development" |
|||
}, |
|||
"extract-i18n": { |
|||
"builder": "@angular-devkit/build-angular:extract-i18n", |
|||
"options": { |
|||
"browserTarget": "prod:build" |
|||
} |
|||
}, |
|||
"test": { |
|||
"builder": "@angular-devkit/build-angular:karma", |
|||
"options": { |
|||
"main": "src/test.ts", |
|||
"polyfills": "src/polyfills.ts", |
|||
"tsConfig": "tsconfig.spec.json", |
|||
"karmaConfig": "karma.conf.js", |
|||
"assets": [ |
|||
"src/favicon.ico", |
|||
"src/assets" |
|||
], |
|||
"styles": [ |
|||
"src/styles.css" |
|||
], |
|||
"scripts": [] |
|||
} |
|||
} |
|||
} |
|||
} |
|||
}, |
|||
"defaultProject": "prod" |
|||
} |
|||
@ -0,0 +1,44 @@ |
|||
// Karma configuration file, see link for more information
|
|||
// https://karma-runner.github.io/1.0/config/configuration-file.html
|
|||
|
|||
module.exports = function (config) { |
|||
config.set({ |
|||
basePath: '', |
|||
frameworks: ['jasmine', '@angular-devkit/build-angular'], |
|||
plugins: [ |
|||
require('karma-jasmine'), |
|||
require('karma-chrome-launcher'), |
|||
require('karma-jasmine-html-reporter'), |
|||
require('karma-coverage'), |
|||
require('@angular-devkit/build-angular/plugins/karma') |
|||
], |
|||
client: { |
|||
jasmine: { |
|||
// you can add configuration options for Jasmine here
|
|||
// the possible options are listed at https://jasmine.github.io/api/edge/Configuration.html
|
|||
// for example, you can disable the random execution with `random: false`
|
|||
// or set a specific seed with `seed: 4321`
|
|||
}, |
|||
clearContext: false // leave Jasmine Spec Runner output visible in browser
|
|||
}, |
|||
jasmineHtmlReporter: { |
|||
suppressAll: true // removes the duplicated traces
|
|||
}, |
|||
coverageReporter: { |
|||
dir: require('path').join(__dirname, './coverage/prod'), |
|||
subdir: '.', |
|||
reporters: [ |
|||
{ type: 'html' }, |
|||
{ type: 'text-summary' } |
|||
] |
|||
}, |
|||
reporters: ['progress', 'kjhtml'], |
|||
port: 9876, |
|||
colors: true, |
|||
logLevel: config.LOG_INFO, |
|||
autoWatch: true, |
|||
browsers: ['Chrome'], |
|||
singleRun: false, |
|||
restartOnFileChange: true |
|||
}); |
|||
}; |
|||
12122
FrontEnd/package-lock.json
File diff suppressed because it is too large
View File
File diff suppressed because it is too large
View File
@ -0,0 +1,39 @@ |
|||
{ |
|||
"name": "prod", |
|||
"version": "0.0.0", |
|||
"scripts": { |
|||
"ng": "ng", |
|||
"start": "ng serve --proxy-config proxy.conf.json", |
|||
"build": "ng build", |
|||
"watch": "ng build --watch --configuration development", |
|||
"test": "ng test" |
|||
}, |
|||
"private": true, |
|||
"dependencies": { |
|||
"@angular/animations": "~12.1.1", |
|||
"@angular/common": "~12.1.1", |
|||
"@angular/compiler": "~12.1.1", |
|||
"@angular/core": "~12.1.1", |
|||
"@angular/forms": "~12.1.1", |
|||
"@angular/platform-browser": "~12.1.1", |
|||
"@angular/platform-browser-dynamic": "~12.1.1", |
|||
"@angular/router": "~12.1.1", |
|||
"rxjs": "~6.6.0", |
|||
"tslib": "^2.2.0", |
|||
"zone.js": "~0.11.4" |
|||
}, |
|||
"devDependencies": { |
|||
"@angular-devkit/build-angular": "~12.1.1", |
|||
"@angular/cli": "~12.1.1", |
|||
"@angular/compiler-cli": "~12.1.1", |
|||
"@types/jasmine": "~3.6.0", |
|||
"@types/node": "^12.11.1", |
|||
"jasmine-core": "~3.7.0", |
|||
"karma": "~6.3.0", |
|||
"karma-chrome-launcher": "~3.1.0", |
|||
"karma-coverage": "~2.0.3", |
|||
"karma-jasmine": "~4.0.0", |
|||
"karma-jasmine-html-reporter": "^1.5.0", |
|||
"typescript": "~4.3.2" |
|||
} |
|||
} |
|||
@ -0,0 +1,12 @@ |
|||
{ |
|||
"/apiProduct/*": { |
|||
"target": "http://localhost:59327", |
|||
"secure": false |
|||
}, |
|||
|
|||
"/apiUser/*":{ |
|||
"target":"http://localhost:59274", |
|||
"secure":false, |
|||
"loglevel":"debug" |
|||
} |
|||
} |
|||
@ -0,0 +1,42 @@ |
|||
import { NgModule } from '@angular/core'; |
|||
import { RouterModule, Routes } from '@angular/router'; |
|||
import { CatalogComponent } from './component/catalog/catalog.component'; |
|||
import { ProductComponent } from './component/product/product.component'; |
|||
import { LoginComponent } from './auth/login/login.component'; |
|||
import { AuthGuardService } from './auth/service/auth-guard.service'; |
|||
import { SignUpComponent } from './auth/sign-up/sign-up.component'; |
|||
import { AccountComponent } from './component/account/account.component'; |
|||
import { HomeComponent } from './component/home/home.component'; |
|||
import { NavbarComponent } from './component/navbar/navbar.component'; |
|||
import { PagenotfoundComponent } from './component/pagenotfound/pagenotfound.component'; |
|||
|
|||
const routes: Routes = [ |
|||
{path: 'product/:pid', component: ProductComponent}, |
|||
{path: 'catalog/:cname', component: CatalogComponent}, |
|||
{path: 'catalog', component: CatalogComponent}, |
|||
{ |
|||
path:'',redirectTo:'/login',pathMatch:'full' |
|||
}, |
|||
{path:'login',component:LoginComponent}, |
|||
{ |
|||
path:'signup',component:SignUpComponent |
|||
}, |
|||
{ |
|||
path:'account',component:AccountComponent |
|||
}, |
|||
{ |
|||
path:'home',component:HomeComponent |
|||
}, |
|||
{ |
|||
path:'navbar',component:NavbarComponent |
|||
}, |
|||
{ |
|||
path:'**',component:PagenotfoundComponent |
|||
} |
|||
]; |
|||
|
|||
@NgModule({ |
|||
imports: [RouterModule.forRoot(routes)], |
|||
exports: [RouterModule] |
|||
}) |
|||
export class AppRoutingModule { } |
|||
@ -0,0 +1,2 @@ |
|||
<app-navbar></app-navbar> |
|||
<router-outlet></router-outlet> |
|||
@ -0,0 +1,35 @@ |
|||
import { TestBed } from '@angular/core/testing'; |
|||
import { RouterTestingModule } from '@angular/router/testing'; |
|||
import { AppComponent } from './app.component'; |
|||
|
|||
describe('AppComponent', () => { |
|||
beforeEach(async () => { |
|||
await TestBed.configureTestingModule({ |
|||
imports: [ |
|||
RouterTestingModule |
|||
], |
|||
declarations: [ |
|||
AppComponent |
|||
], |
|||
}).compileComponents(); |
|||
}); |
|||
|
|||
it('should create the app', () => { |
|||
const fixture = TestBed.createComponent(AppComponent); |
|||
const app = fixture.componentInstance; |
|||
expect(app).toBeTruthy(); |
|||
}); |
|||
|
|||
it(`should have as title 'prod'`, () => { |
|||
const fixture = TestBed.createComponent(AppComponent); |
|||
const app = fixture.componentInstance; |
|||
expect(app.title).toEqual('prod'); |
|||
}); |
|||
|
|||
it('should render title', () => { |
|||
const fixture = TestBed.createComponent(AppComponent); |
|||
fixture.detectChanges(); |
|||
const compiled = fixture.nativeElement; |
|||
expect(compiled.querySelector('.content span').textContent).toContain('prod app is running!'); |
|||
}); |
|||
}); |
|||
@ -0,0 +1,10 @@ |
|||
import { Component } from '@angular/core'; |
|||
|
|||
@Component({ |
|||
selector: 'app-root', |
|||
templateUrl: './app.component.html', |
|||
styleUrls: ['./app.component.css'] |
|||
}) |
|||
export class AppComponent { |
|||
title = 'prod'; |
|||
} |
|||
@ -0,0 +1,38 @@ |
|||
import { NgModule } from '@angular/core'; |
|||
import { BrowserModule } from '@angular/platform-browser'; |
|||
import { HttpClientModule } from '@angular/common/http'; |
|||
import { AppRoutingModule } from './app-routing.module'; |
|||
import { AppComponent } from './app.component'; |
|||
import { ProductComponent } from './component/product/product.component'; |
|||
import { CatalogComponent } from './component/catalog/catalog.component'; |
|||
import { LoginComponent } from './auth/login/login.component'; |
|||
import { SignUpComponent } from './auth/sign-up/sign-up.component'; |
|||
import { PagenotfoundComponent } from './component/pagenotfound/pagenotfound.component'; |
|||
import { NavbarComponent } from './component/navbar/navbar.component'; |
|||
import { ReactiveFormsModule } from '@angular/forms'; |
|||
import { HomeComponent } from './component/home/home.component'; |
|||
import { AccountComponent } from './component/account/account.component'; |
|||
|
|||
|
|||
@NgModule({ |
|||
declarations: [ |
|||
AppComponent, |
|||
ProductComponent, |
|||
CatalogComponent, |
|||
LoginComponent, |
|||
SignUpComponent, |
|||
PagenotfoundComponent, |
|||
NavbarComponent, |
|||
HomeComponent, |
|||
AccountComponent |
|||
], |
|||
imports: [ |
|||
BrowserModule, |
|||
HttpClientModule, |
|||
ReactiveFormsModule, |
|||
AppRoutingModule |
|||
], |
|||
providers: [], |
|||
bootstrap: [AppComponent] |
|||
}) |
|||
export class AppModule { } |
|||
@ -0,0 +1,46 @@ |
|||
<div class="container-fluid" style="height:100%;border:1px solid black;bottom:0px;overflow:hidden;"> |
|||
<div class="row"> |
|||
<div class="col-md-8" style="background-image: url('assets/images/Logo.png');background-repeat: no-repeat; |
|||
background-size: cover;"> |
|||
</div> |
|||
<!-- ========================= SECTION CONTENT ========================= --> |
|||
<div class="col-lg-4"> |
|||
<section class="section-conten padding-y" style="min-height:99.7vh;overflow:hidden;"> |
|||
|
|||
<!-- ============================ COMPONENT LOGIN ================================= --> |
|||
<div class="card mx-auto" style="max-width: 380px; margin-top:125.5px;"> |
|||
<div class="card-body"> |
|||
<h4 class="card-title mb-4">Sign in</h4> |
|||
<form [formGroup]='loginForm' (submit)='onloginFormSubmit()'> |
|||
<a href="#" class="btn btn-google btn-block mb-4"> <i class="fab fa-google"></i> Sign in with Google</a> |
|||
<p>{{msg}}</p> |
|||
<div class="form-group"> |
|||
<input name="" class="form-control" placeholder="Username" type="text" formControlName="username"> |
|||
<div *ngIf="loginForm.controls['username'].invalid && (loginForm.controls['username'].touched)" style="color:red;">Invalid UserName</div> |
|||
</div> <!-- form-group// --> |
|||
<div class="form-group"> |
|||
<input name="" class="form-control" placeholder="Password" type="password" formControlName="password"> |
|||
<div *ngIf="loginForm.controls['password'].invalid && (loginForm.controls['password'].touched)" style="color:red;">Invalid Password</div> |
|||
</div> <!-- form-group// --> |
|||
|
|||
<div class="form-group"> |
|||
<a href="#" class="float-right">Forgot password?</a> |
|||
<label class="float-left custom-control custom-checkbox"> <input type="checkbox" class="custom-control-input" checked=""> <div class="custom-control-label"> Remember </div> </label> |
|||
</div> <!-- form-group form-check .// --> |
|||
<div class="form-group"> |
|||
<button type="submit" class="btn btn-primary btn-block" [disabled]='!loginForm.valid'> Login </button> |
|||
</div> <!-- form-group// --> |
|||
</form> |
|||
</div> <!-- card-body.// --> |
|||
</div> <!-- card .// --> |
|||
|
|||
<p class="text-center mt-4">Don't have account? <a routerLink="/signup">Sign-Up</a></p> |
|||
<br><br> |
|||
</section> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<router-outlet></router-outlet> |
|||
|
|||
<!-- ========================= FOOTER END // ========================= --> |
|||
|
|||
@ -0,0 +1,25 @@ |
|||
import { ComponentFixture, TestBed } from '@angular/core/testing'; |
|||
|
|||
import { LoginComponent } from './login.component'; |
|||
|
|||
describe('LoginComponent', () => { |
|||
let component: LoginComponent; |
|||
let fixture: ComponentFixture<LoginComponent>; |
|||
|
|||
beforeEach(async () => { |
|||
await TestBed.configureTestingModule({ |
|||
declarations: [ LoginComponent ] |
|||
}) |
|||
.compileComponents(); |
|||
}); |
|||
|
|||
beforeEach(() => { |
|||
fixture = TestBed.createComponent(LoginComponent); |
|||
component = fixture.componentInstance; |
|||
fixture.detectChanges(); |
|||
}); |
|||
|
|||
it('should create', () => { |
|||
expect(component).toBeTruthy(); |
|||
}); |
|||
}); |
|||
@ -0,0 +1,43 @@ |
|||
import { Component, OnInit } from '@angular/core'; |
|||
import { FormGroup, FormControl, Validators } from '@angular/forms'; |
|||
import { Router } from '@angular/router'; |
|||
import { User } from 'src/app/model/user.model'; |
|||
import { AppserviceService } from 'src/app/service/appservice.service'; |
|||
import { UserServiceService } from 'src/app/service/user-service.service'; |
|||
|
|||
@Component({ |
|||
selector: 'app-login', |
|||
templateUrl: './login.component.html', |
|||
styleUrls: ['./login.component.css'] |
|||
}) |
|||
export class LoginComponent implements OnInit { |
|||
|
|||
user:User=new User(); |
|||
loginForm:FormGroup; |
|||
msg:string; |
|||
constructor(private route:Router,private userService:UserServiceService,private appService:AppserviceService) { |
|||
this.msg=""; |
|||
} |
|||
|
|||
ngOnInit(): void { |
|||
this.loginForm=new FormGroup( |
|||
{ |
|||
username:new FormControl('',Validators.required), |
|||
password:new FormControl('',Validators.required), |
|||
} |
|||
); |
|||
} |
|||
onloginFormSubmit(){ |
|||
console.log(this.loginForm.value.username); |
|||
this.userService.getUser(this.loginForm.value).subscribe(data=>{ |
|||
window.localStorage.setItem('username',this.loginForm.value.username); |
|||
window.localStorage.setItem('isLoggedIn','true'); |
|||
this.appService.activate.next(true); |
|||
//this.authService.isAuthenticated();
|
|||
this.route.navigateByUrl('/home'); |
|||
},(err:any)=>{ |
|||
console.log(err) |
|||
this.msg="Invalid Credentials"; |
|||
}); |
|||
|
|||
}} |
|||
@ -0,0 +1,16 @@ |
|||
import { TestBed } from '@angular/core/testing'; |
|||
|
|||
import { AuthGuardService } from './auth-guard.service'; |
|||
|
|||
describe('AuthGuardService', () => { |
|||
let service: AuthGuardService; |
|||
|
|||
beforeEach(() => { |
|||
TestBed.configureTestingModule({}); |
|||
service = TestBed.inject(AuthGuardService); |
|||
}); |
|||
|
|||
it('should be created', () => { |
|||
expect(service).toBeTruthy(); |
|||
}); |
|||
}); |
|||
@ -0,0 +1,20 @@ |
|||
import { Injectable } from '@angular/core'; |
|||
import { Router, ActivatedRouteSnapshot, RouterStateSnapshot, UrlTree } from '@angular/router'; |
|||
import { Observable } from 'rxjs'; |
|||
import { AuthService } from './auth.service'; |
|||
|
|||
@Injectable({ |
|||
providedIn: 'root' |
|||
}) |
|||
export class AuthGuardService { |
|||
status:boolean; |
|||
constructor(private authService:AuthService,private route:Router) { } |
|||
canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): boolean | UrlTree | Observable<boolean | UrlTree> | Promise<boolean | UrlTree> { |
|||
this.status=this.authService.isAuthenticated(); |
|||
console.log("status",this.status); |
|||
if(this.status==false){ |
|||
this.route.navigateByUrl('/login'); |
|||
} |
|||
return true; |
|||
} |
|||
} |
|||
@ -0,0 +1,16 @@ |
|||
import { TestBed } from '@angular/core/testing'; |
|||
|
|||
import { AuthService } from './auth.service'; |
|||
|
|||
describe('AuthService', () => { |
|||
let service: AuthService; |
|||
|
|||
beforeEach(() => { |
|||
TestBed.configureTestingModule({}); |
|||
service = TestBed.inject(AuthService); |
|||
}); |
|||
|
|||
it('should be created', () => { |
|||
expect(service).toBeTruthy(); |
|||
}); |
|||
}); |
|||
@ -0,0 +1,17 @@ |
|||
import { Injectable } from '@angular/core'; |
|||
|
|||
@Injectable({ |
|||
providedIn: 'root' |
|||
}) |
|||
export class AuthService { |
|||
|
|||
constructor() { } |
|||
isAuthenticated():boolean{ |
|||
if(window.localStorage.getItem('isLoggedIn')=='true'){ |
|||
//console.log("true");
|
|||
return true;} |
|||
//frm local storage we read the value of username/isLoggedIn and decide
|
|||
|
|||
return false; |
|||
} |
|||
} |
|||
@ -0,0 +1,89 @@ |
|||
<div class="container-fluid" style="height:50%;border:1px solid black;bottom:0px;overflow:hidden;"> |
|||
<div class="row"> |
|||
<div class="col-md-8" style="background-image: url('assets/images/Logo.png');background-repeat: no-repeat; |
|||
background-size: cover;"> |
|||
</div> |
|||
<div class="col-lg-4"> |
|||
<section class="section-content padding-y" style="min-height:99.5vh;overflow:hidden;margin-top:2px"> |
|||
<div class="card mx-auto" style="max-width:520px; margin-top:2px"> |
|||
<div class="card-body"> |
|||
<h4 class="card-title">Sign up</h4> |
|||
<form [formGroup]='signUpForm' (submit)='onSignUpSubmit()'> |
|||
<p>{{msg}}</p> |
|||
<div class="form-row"> |
|||
<div class="col form-group"> |
|||
<label>name</label> |
|||
<input type="text" class="form-control" placeholder="" formControlName="name"> |
|||
<div *ngIf="signUpForm.controls['name'].invalid && (signUpForm.controls['name'].touched)" style="color:red;">Invalid Name</div> |
|||
</div> |
|||
<div class="col form-group"> |
|||
<label>user name</label> |
|||
<input type="text" class="form-control" placeholder="" formControlName="username"> |
|||
<div *ngIf="signUpForm.controls['username'].invalid && (signUpForm.controls['username'].touched)" style="color:red;">Invalid UserName</div> |
|||
</div> |
|||
</div> |
|||
<div class="form-group"> |
|||
<label>Email</label> |
|||
<input type="email" class="form-control" placeholder="" formControlName="email"> |
|||
<div *ngIf="signUpForm.controls['email'].invalid && (signUpForm.controls['email'].touched)" style="color:red;">Invalid Email</div> |
|||
</div> |
|||
<!-- <div class="form-group"> |
|||
<label class="custom-control custom-radio custom-control-inline"> |
|||
<input class="custom-control-input" checked="" type="radio" name="gender" value="option1"> |
|||
<span class="custom-control-label"> Male </span> |
|||
</label> |
|||
<label class="custom-control custom-radio custom-control-inline"> |
|||
<input class="custom-control-input" type="radio" name="gender" value="option2"> |
|||
<span class="custom-control-label"> Female </span> |
|||
</label> |
|||
</div> --> |
|||
<div class="form-row"> |
|||
<div class="form-group col-md-6"> |
|||
<label>Address</label> |
|||
<input type="text" class="form-control" formControlName="address"> |
|||
<div *ngIf="signUpForm.controls['address'].invalid && (signUpForm.controls['address'].touched)" style="color:red;">Invalid Address</div> |
|||
</div> |
|||
<!-- <div class="form-group col-md-6"> |
|||
<label>Country</label> |
|||
<select id="inputState" class="form-control"> |
|||
<option> Choose...</option> |
|||
<option>Uzbekistan</option> |
|||
<option>Russia</option> |
|||
<option selected="">United States</option> |
|||
<option>India</option> |
|||
<option>Afganistan</option> |
|||
</select> |
|||
</div> --> |
|||
</div> |
|||
<div class="form-row"> |
|||
<div class="form-group col-md-6"> |
|||
<label>Create password</label> |
|||
<input class="form-control" type="password" formControlName="password"> |
|||
<div *ngIf="signUpForm.controls['password'].invalid && (signUpForm.controls['password'].touched)" style="color:red;">Invalid Password</div> |
|||
|
|||
</div> |
|||
<div class="form-group col-md-6"> |
|||
<label>Mobile</label> |
|||
<input class="form-control" type="text" formControlName="mobile"> |
|||
<div *ngIf="signUpForm.controls['mobile'].invalid && (signUpForm.controls['mobile'].touched)" style="color:red;">Invalid</div> |
|||
|
|||
</div> |
|||
</div> |
|||
<div class="form-group"> |
|||
<button type="submit" class="btn btn-primary btn-block" [disabled]='!signUpForm.valid'> Register </button> |
|||
</div> |
|||
<!-- <div class="form-group"> |
|||
<label class="custom-control custom-checkbox"> <input type="checkbox" class="custom-control-input" checked=""> <div class="custom-control-label"> I am agree with <a href="#">terms and contitions</a> </div> </label> |
|||
</div> --> |
|||
</form> |
|||
</div> |
|||
</div> |
|||
<p class="text-center mt-4">Have an account? <a routerLink="/login">Log In</a></p> |
|||
<br><br> |
|||
</section> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
|
|||
|
|||
|
|||
@ -0,0 +1,25 @@ |
|||
import { ComponentFixture, TestBed } from '@angular/core/testing'; |
|||
|
|||
import { SignUpComponent } from './sign-up.component'; |
|||
|
|||
describe('SignUpComponent', () => { |
|||
let component: SignUpComponent; |
|||
let fixture: ComponentFixture<SignUpComponent>; |
|||
|
|||
beforeEach(async () => { |
|||
await TestBed.configureTestingModule({ |
|||
declarations: [ SignUpComponent ] |
|||
}) |
|||
.compileComponents(); |
|||
}); |
|||
|
|||
beforeEach(() => { |
|||
fixture = TestBed.createComponent(SignUpComponent); |
|||
component = fixture.componentInstance; |
|||
fixture.detectChanges(); |
|||
}); |
|||
|
|||
it('should create', () => { |
|||
expect(component).toBeTruthy(); |
|||
}); |
|||
}); |
|||
@ -0,0 +1,48 @@ |
|||
import { Component, OnInit } from '@angular/core'; |
|||
import { FormGroup, FormControl, Validators } from '@angular/forms'; |
|||
import { Router } from '@angular/router'; |
|||
import { UserServiceService } from 'src/app/service/user-service.service'; |
|||
|
|||
@Component({ |
|||
selector: 'app-sign-up', |
|||
templateUrl: './sign-up.component.html', |
|||
styleUrls: ['./sign-up.component.css'] |
|||
}) |
|||
export class SignUpComponent implements OnInit { |
|||
|
|||
signUpForm:FormGroup; |
|||
msg:String=''; |
|||
emailPattern: string | RegExp; |
|||
namePattern:string | RegExp; |
|||
constructor(private userService:UserServiceService,private route:Router) { |
|||
this.emailPattern = "^[a-z0-9._%+-]+@[a-z0-9.-]+\.[a-z]{2,4}$"; |
|||
this.namePattern="^[a-zA-Z][a-zA-Z ]+$" |
|||
} |
|||
|
|||
ngOnInit(): void { |
|||
this.signUpForm=new FormGroup( |
|||
{ |
|||
name:new FormControl('',[Validators.required,Validators.maxLength(30), |
|||
Validators.pattern(this.namePattern)]), |
|||
username:new FormControl('',Validators.required), |
|||
password:new FormControl('',Validators.required), |
|||
mobile:new FormControl('',[Validators.required,Validators.pattern(/^[6-9]\d{9}$/),Validators.maxLength(10)]), |
|||
email:new FormControl('',[Validators.required,Validators.pattern(this.emailPattern)]), |
|||
address:new FormControl('',Validators.required) |
|||
} |
|||
); |
|||
} |
|||
onSignUpSubmit(){ |
|||
console.log(this.signUpForm.value); |
|||
this.userService.postUser(this.signUpForm.value).subscribe(data=>{ |
|||
this.signUpForm.reset(); |
|||
this.route.navigateByUrl('/login?msg=Success'); |
|||
},(err:any)=>{ |
|||
console.log(err); |
|||
this.msg="UserName might already be taken." |
|||
}) |
|||
} |
|||
|
|||
|
|||
|
|||
} |
|||
@ -0,0 +1,87 @@ |
|||
<div class="container-fluid" style="height:50%;border:1px solid black;bottom:0px;overflow:hidden;"> |
|||
<div class="row"> |
|||
<!--<div class="col-md-8" style="background-image: url('assets/images/Logo.png');background-repeat: no-repeat; |
|||
background-size: cover;"> |
|||
</div>--> |
|||
<div class="col-md-12"> |
|||
<section class="section-content padding-y" style="min-height:99.5vh;overflow:hidden;margin-top:2px"> |
|||
<div class="card mx-auto" style="max-width:520px; margin-top:2px"> |
|||
<div class="card-body"> |
|||
<h4 class="card-title">Profile</h4> |
|||
<form [formGroup]='signUpForm' (submit)='onUpdate()'> |
|||
<div class="form-row"> |
|||
<div class="col form-group"> |
|||
<label>name</label> |
|||
<input type="text" class="form-control" placeholder="" formControlName="name"> |
|||
<div *ngIf="signUpForm.controls['name'].invalid && (signUpForm.controls['name'].touched)" style="color:red;">Invalid Name</div> |
|||
</div> |
|||
<div class="col form-group"> |
|||
<label>user name</label> |
|||
<input type="text" class="form-control" placeholder="" formControlName="username" readonly> |
|||
<div *ngIf="signUpForm.controls['username'].invalid && (signUpForm.controls['username'].touched)" style="color:red;">Invalid UserName</div> |
|||
</div> |
|||
</div> |
|||
<div class="form-group"> |
|||
<label>Email</label> |
|||
<input type="email" class="form-control" placeholder="" formControlName="email"> |
|||
<div *ngIf="signUpForm.controls['email'].invalid && (signUpForm.controls['email'].touched)" style="color:red;">Invalid Email</div> |
|||
</div> |
|||
<!-- <div class="form-group"> |
|||
<label class="custom-control custom-radio custom-control-inline"> |
|||
<input class="custom-control-input" checked="" type="radio" name="gender" value="option1"> |
|||
<span class="custom-control-label"> Male </span> |
|||
</label> |
|||
<label class="custom-control custom-radio custom-control-inline"> |
|||
<input class="custom-control-input" type="radio" name="gender" value="option2"> |
|||
<span class="custom-control-label"> Female </span> |
|||
</label> |
|||
</div> --> |
|||
<div class="form-row"> |
|||
<div class="form-group col-md-6"> |
|||
<label>Address</label> |
|||
<input type="text" class="form-control" formControlName="address"> |
|||
<div *ngIf="signUpForm.controls['address'].invalid && (signUpForm.controls['address'].touched)" style="color:red;">Invalid Address</div> |
|||
</div> |
|||
<!-- <div class="form-group col-md-6"> |
|||
<label>Country</label> |
|||
<select id="inputState" class="form-control"> |
|||
<option> Choose...</option> |
|||
<option>Uzbekistan</option> |
|||
<option>Russia</option> |
|||
<option selected="">United States</option> |
|||
<option>India</option> |
|||
<option>Afganistan</option> |
|||
</select> |
|||
</div> --> |
|||
</div> |
|||
<div class="form-row"> |
|||
<div class="form-group col-md-6"> |
|||
<label>Create password</label> |
|||
<input class="form-control" type="password" formControlName="password"> |
|||
<div *ngIf="signUpForm.controls['password'].invalid && (signUpForm.controls['password'].touched)" style="color:red;">Invalid Password</div> |
|||
|
|||
</div> |
|||
<div class="form-group col-md-6"> |
|||
<label>Mobile</label> |
|||
<input class="form-control" type="text" formControlName="mobile"> |
|||
<div *ngIf="signUpForm.controls['mobile'].invalid && (signUpForm.controls['mobile'].touched)" style="color:red;">Invalid</div> |
|||
|
|||
</div> |
|||
</div> |
|||
<div class="form-group"> |
|||
<button type="submit" class="btn btn-primary btn-block" [disabled]='!signUpForm.valid'> Update </button> |
|||
</div> |
|||
<!-- <div class="form-group"> |
|||
<label class="custom-control custom-checkbox"> <input type="checkbox" class="custom-control-input" checked=""> <div class="custom-control-label"> I am agree with <a href="#">terms and contitions</a> </div> </label> |
|||
</div> --> |
|||
</form> |
|||
</div> |
|||
</div> |
|||
<br><br> |
|||
</section> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
|
|||
|
|||
|
|||
@ -0,0 +1,25 @@ |
|||
import { ComponentFixture, TestBed } from '@angular/core/testing'; |
|||
|
|||
import { AccountComponent } from './account.component'; |
|||
|
|||
describe('AccountComponent', () => { |
|||
let component: AccountComponent; |
|||
let fixture: ComponentFixture<AccountComponent>; |
|||
|
|||
beforeEach(async () => { |
|||
await TestBed.configureTestingModule({ |
|||
declarations: [ AccountComponent ] |
|||
}) |
|||
.compileComponents(); |
|||
}); |
|||
|
|||
beforeEach(() => { |
|||
fixture = TestBed.createComponent(AccountComponent); |
|||
component = fixture.componentInstance; |
|||
fixture.detectChanges(); |
|||
}); |
|||
|
|||
it('should create', () => { |
|||
expect(component).toBeTruthy(); |
|||
}); |
|||
}); |
|||
@ -0,0 +1,51 @@ |
|||
import { Component, OnInit, Output } from '@angular/core'; |
|||
import { FormGroup, FormControl, Validators } from '@angular/forms'; |
|||
import { Router } from '@angular/router'; |
|||
import { User } from 'src/app/model/user.model'; |
|||
import { AppserviceService } from 'src/app/service/appservice.service'; |
|||
import { UserServiceService } from 'src/app/service/user-service.service'; |
|||
|
|||
@Component({ |
|||
selector: 'app-account', |
|||
templateUrl: './account.component.html', |
|||
styleUrls: ['./account.component.css'] |
|||
}) |
|||
export class AccountComponent implements OnInit { |
|||
|
|||
signUpForm:FormGroup; |
|||
msg:String=''; |
|||
emailPattern: string | RegExp; |
|||
namePattern:string | RegExp; |
|||
constructor(private userService:UserServiceService,private route:Router,private appService:AppserviceService) { |
|||
this.emailPattern = "^[a-z0-9._%+-]+@[a-z0-9.-]+\.[a-z]{2,4}$"; |
|||
this.namePattern="^[a-zA-Z][a-zA-Z ]+$" |
|||
} |
|||
|
|||
ngOnInit(): void { |
|||
this.appService.userDetails.subscribe(data=>{ |
|||
this.signUpForm=new FormGroup( |
|||
{ |
|||
name:new FormControl(data.name,[Validators.required,Validators.maxLength(30), |
|||
Validators.pattern(this.namePattern)]), |
|||
username:new FormControl(data.username,Validators.required), |
|||
password:new FormControl('',Validators.required), |
|||
mobile:new FormControl(data.mobile,[Validators.required,Validators.pattern(/^[6-9]\d{9}$/),Validators.maxLength(10)]), |
|||
email:new FormControl(data.email,[Validators.required,Validators.pattern(this.emailPattern)]), |
|||
address:new FormControl(data.address,Validators.required) |
|||
} |
|||
);}) |
|||
} |
|||
onUpdate(){ |
|||
console.log(this.signUpForm.value); |
|||
this.userService.updateUser(this.signUpForm.value).subscribe(data=>{ |
|||
window.localStorage.setItem("auth",btoa(data.username+":"+data.password)) |
|||
alert("Updated Successfully") |
|||
},(err:any)=>{ |
|||
console.log(err) |
|||
}) |
|||
} |
|||
|
|||
|
|||
|
|||
|
|||
} |
|||
@ -0,0 +1,152 @@ |
|||
<!-- ========================= SECTION PAGETOP ========================= --> |
|||
<section class="section-pagetop bg"> |
|||
<div class="container"> |
|||
<h2 class="title-page" *ngIf="query==undefined; else elseBlock">Category products</h2> |
|||
<ng-template #elseBlock><h2 class="title-page">Search Results</h2></ng-template> |
|||
<nav> |
|||
<ol class="breadcrumb text-white"> |
|||
<li class="breadcrumb-item"><a href="/home">Home</a></li> |
|||
</ol> |
|||
</nav> |
|||
</div> <!-- container // --> |
|||
</section> |
|||
<!-- ========================= SECTION INTRO END// ========================= --> |
|||
|
|||
<!-- ========================= SECTION CONTENT ========================= --> |
|||
<section class="section-content padding-y"> |
|||
<div class="container"> |
|||
|
|||
<div class="row"> |
|||
<aside class="col-md-3"> |
|||
|
|||
<div class="card"> |
|||
<article class="filter-group"> |
|||
<header class="card-header"> |
|||
<a href="#" data-toggle="collapse" data-target="#collapse_1" aria-expanded="true" class=""> |
|||
<i class="icon-control fa fa-chevron-down"></i> |
|||
<h6 class="title">Other categories</h6> |
|||
</a> |
|||
</header> |
|||
<div class="filter-content collapse show" id="collapse_1"> |
|||
<div class="card-body"> |
|||
|
|||
<ul class="list-menu"> |
|||
<li *ngIf="cname!='Electronics';"><a href="catalog/Electronics">Electronics</a></li> |
|||
<li *ngIf="cname!='Clothes';"><a href="catalog/Clothes">Clothes</a></li> |
|||
<li *ngIf="cname!='Sports';"><a href="catalog/Sports">Sports</a></li> |
|||
</ul> |
|||
|
|||
</div> <!-- card-body.// --> |
|||
</div> |
|||
</article> <!-- filter-group .// --> |
|||
|
|||
</div> <!-- card.// --> |
|||
|
|||
</aside> <!-- col.// --> |
|||
<main class="col-md-9"> |
|||
|
|||
<!-- <header class="border-bottom mb-4 pb-3"> |
|||
<div class="form-inline"> |
|||
<span class="mr-md-auto">32 Items found </span> |
|||
<select class="mr-2 form-control"> |
|||
<option>Latest items</option> |
|||
<option>Trending</option> |
|||
<option>Most Popular</option> |
|||
<option>Cheapest</option> |
|||
</select> |
|||
<div class="btn-group"> |
|||
<a href="#" class="btn btn-outline-secondary" data-toggle="tooltip" title="List view"> |
|||
<i class="fa fa-bars"></i></a> |
|||
<a href="#" class="btn btn-outline-secondary active" data-toggle="tooltip" title="Grid view"> |
|||
<i class="fa fa-th"></i></a> |
|||
</div> |
|||
</div> |
|||
</header> --> |
|||
|
|||
|
|||
|
|||
<div class="row"> |
|||
<div class="col-md-4" *ngFor='let product of products'> |
|||
<figure class="card card-product-grid"> |
|||
<div class="img-wrap"> |
|||
<!-- <span class="badge badge-danger"> NEW </span> --> |
|||
<img src="{{product.picture}}"> |
|||
</div> <!-- img-wrap.// --> |
|||
<figcaption class="info-wrap"> |
|||
<div class="fix-height"> |
|||
<a href="/product/{{product.id}}" class="text-primary">{{product.name}}</a> |
|||
<div class="price-wrap mt-2"> |
|||
<span class="price">₹{{product.price}}</span> |
|||
<del class="price-old">₹{{product.price + 100}}</del> |
|||
</div> <!-- price-wrap.// --> |
|||
<div>Rating: {{product.rating}}/5</div> |
|||
</div> |
|||
<a href="javascript:void(0);" class="btn btn-block btn-primary" (click)="addToCart(product.id)">Add to Cart </a> |
|||
</figcaption> |
|||
</figure> |
|||
</div> <!-- col.// --> |
|||
</div> <!-- row end.// --> |
|||
|
|||
|
|||
<nav class="mt-4" aria-label="Page navigation sample"> |
|||
<ul class="pagination"> |
|||
<li class="page-item disabled"><a class="page-link" href="#">Previous</a></li> |
|||
<li class="page-item active"><a class="page-link" href="#">1</a></li> |
|||
<li class="page-item"><a class="page-link" href="#">2</a></li> |
|||
<li class="page-item"><a class="page-link" href="#">3</a></li> |
|||
<li class="page-item"><a class="page-link" href="#">Next</a></li> |
|||
</ul> |
|||
</nav> |
|||
|
|||
</main> <!-- col.// --> |
|||
|
|||
</div> |
|||
|
|||
</div> <!-- container .// --> |
|||
</section> |
|||
<!-- ========================= SECTION CONTENT END// ========================= --> |
|||
|
|||
<!-- ========================= FOOTER ========================= --> |
|||
<footer class="section-footer border-top padding-y"> |
|||
<div class="container"> |
|||
<p class="float-md-right"> |
|||
© Copyright 2021 All rights reserved |
|||
</p> |
|||
<p> |
|||
<a href="#">Terms and conditions</a> |
|||
</p> |
|||
</div><!-- //container --> |
|||
</footer> |
|||
<!-- ========================= FOOTER END // ========================= --> |
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
<!-- <form action="/catalog"> |
|||
<input type="text" placeholder="Search.." name="search"> |
|||
<button type="submit">Submit</button> |
|||
</form> |
|||
|
|||
<div *ngFor = 'let product of products'> |
|||
Name: {{product?.name}} |
|||
Picture: {{product?.picture}} |
|||
Price: {{product?.price}} |
|||
Rating: {{product?.rating}} |
|||
Vendor Name: {{product?.vendorName}} |
|||
Category: {{product?.category}} |
|||
Description: {{product?.description}} |
|||
Quantity: {{product?.quantity}} |
|||
|
|||
<a routerLink="/product/{{product.id}}">VIEW PRODUCT</a> |
|||
<br><br><br> |
|||
</div> --> |
|||
@ -0,0 +1,25 @@ |
|||
import { ComponentFixture, TestBed } from '@angular/core/testing'; |
|||
|
|||
import { CatalogComponent } from './catalog.component'; |
|||
|
|||
describe('CatalogComponent', () => { |
|||
let component: CatalogComponent; |
|||
let fixture: ComponentFixture<CatalogComponent>; |
|||
|
|||
beforeEach(async () => { |
|||
await TestBed.configureTestingModule({ |
|||
declarations: [ CatalogComponent ] |
|||
}) |
|||
.compileComponents(); |
|||
}); |
|||
|
|||
beforeEach(() => { |
|||
fixture = TestBed.createComponent(CatalogComponent); |
|||
component = fixture.componentInstance; |
|||
fixture.detectChanges(); |
|||
}); |
|||
|
|||
it('should create', () => { |
|||
expect(component).toBeTruthy(); |
|||
}); |
|||
}); |
|||
@ -0,0 +1,43 @@ |
|||
import { Component, OnInit } from '@angular/core'; |
|||
import { ActivatedRoute } from '@angular/router'; |
|||
import { Product } from 'src/app/model/product.model'; |
|||
import { ProductService } from 'src/app/service/product.service'; |
|||
import { filter } from 'rxjs/operators'; |
|||
|
|||
@Component({ |
|||
selector: 'app-catalog', |
|||
templateUrl: './catalog.component.html', |
|||
styleUrls: ['./catalog.component.css'] |
|||
}) |
|||
export class CatalogComponent implements OnInit { |
|||
products: Product[]; |
|||
cname: string; |
|||
query : string; |
|||
constructor(private actRoute : ActivatedRoute, private productService : ProductService) { } |
|||
|
|||
ngOnInit(): void { |
|||
this.products =[]; |
|||
this.cname = undefined; |
|||
this.query = undefined; |
|||
this.actRoute.paramMap.subscribe(params => {this.cname = params.get('cname')}); |
|||
|
|||
this.actRoute.queryParams.pipe(filter(params => params.search)).subscribe(params => { |
|||
console.log(params); |
|||
this.query = params.search; |
|||
} |
|||
); |
|||
|
|||
this.productService.searchProducts(this.query).subscribe(data =>{ |
|||
if(this.query != undefined){this.products = data;} |
|||
}); |
|||
|
|||
this.productService.getAllProductsByCategory(this.cname).subscribe(data => { |
|||
if(this.cname != undefined){this.products = data;} |
|||
}); |
|||
} |
|||
|
|||
public addToCart(id: number){ |
|||
this.productService.addItemToCart(id); |
|||
} |
|||
|
|||
} |
|||
@ -0,0 +1,3 @@ |
|||
img{ |
|||
height: 16rem; |
|||
} |
|||
@ -0,0 +1,27 @@ |
|||
<div class="container-fluid" style="height:50%;bottom:0px;overflow:hidden;padding:0%;"> |
|||
<img src="assets/images/Sale.jpg" width="100%" style="margin:0px;"> |
|||
</div> |
|||
<div class="container-fluid" style="height:50%;bottom:0px;overflow:hidden;"> |
|||
<div class="row"> |
|||
<div class="card" style="width: 12rem;" class="col-md-4"> |
|||
<img src="assets/images/Electronics.jpg" class="card-img-top" alt="Electronics"> |
|||
<div class="card-body"> |
|||
<h5 class="card-title">Electronics</h5> |
|||
<a href="catalog/Electronics" class="btn btn-primary">Shop</a> |
|||
</div> |
|||
</div> |
|||
<div class="card" style="width: 12rem;" class="col-md-4"> |
|||
<img src="assets/images/Clothes.jpg" class="card-img-top" alt="Clothes"> |
|||
<div class="card-body"> |
|||
<h5 class="card-title">Clothes</h5> |
|||
<a href="catalog/Clothes" class="btn btn-primary">Shop</a> |
|||
</div> |
|||
</div> |
|||
<div class="card" style="width: 12rem;" class="col-md-4"> |
|||
<img src="assets/images/Sports.jpg" class="card-img-top" alt="Sports"> |
|||
<div class="card-body"> |
|||
<h5 class="card-title">Sports</h5> |
|||
<a href="catalog/Sports" class="btn btn-primary">Shop</a> |
|||
</div> |
|||
</div></div> |
|||
<div> |
|||
@ -0,0 +1,25 @@ |
|||
import { ComponentFixture, TestBed } from '@angular/core/testing'; |
|||
|
|||
import { HomeComponent } from './home.component'; |
|||
|
|||
describe('HomeComponent', () => { |
|||
let component: HomeComponent; |
|||
let fixture: ComponentFixture<HomeComponent>; |
|||
|
|||
beforeEach(async () => { |
|||
await TestBed.configureTestingModule({ |
|||
declarations: [ HomeComponent ] |
|||
}) |
|||
.compileComponents(); |
|||
}); |
|||
|
|||
beforeEach(() => { |
|||
fixture = TestBed.createComponent(HomeComponent); |
|||
component = fixture.componentInstance; |
|||
fixture.detectChanges(); |
|||
}); |
|||
|
|||
it('should create', () => { |
|||
expect(component).toBeTruthy(); |
|||
}); |
|||
}); |
|||
@ -0,0 +1,16 @@ |
|||
import { Component, OnInit } from '@angular/core'; |
|||
|
|||
@Component({ |
|||
selector: 'app-home', |
|||
templateUrl: './home.component.html', |
|||
styleUrls: ['./home.component.css'] |
|||
}) |
|||
export class HomeComponent implements OnInit { |
|||
|
|||
constructor() { } |
|||
|
|||
ngOnInit(): void { |
|||
console.log(window.location.pathname) |
|||
} |
|||
|
|||
} |
|||
@ -0,0 +1,42 @@ |
|||
<nav class="navbar navbar-expand-lg navbar-dark bg-dark" [hidden]="!activate"> |
|||
<!--<a class="navbar-brand" href="#">Navbar</a> |
|||
<button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarSupportedContent" aria-controls="navbarSupportedContent" aria-expanded="false" aria-label="Toggle navigation"> |
|||
<span class="navbar-toggler-icon"></span> |
|||
</button>--> |
|||
|
|||
<div class="collapse navbar-collapse" id="navbarSupportedContent"> |
|||
<ul class="navbar-nav mr-auto"> |
|||
<li class="nav-item active"> |
|||
<a class="nav-link" routerLink="/home">Home <span class="sr-only">(current)</span></a> |
|||
</li> |
|||
<!--<li class="nav-item"> |
|||
<a class="nav-link" href="#">Link</a> |
|||
</li> |
|||
|
|||
<li class="nav-item"> |
|||
<a class="nav-link disabled" href="#">Disabled</a> |
|||
</li>--> |
|||
<li class="nav-item"> |
|||
<form class="form-inline my-2 my-lg-0" [hidden]='!rou' action="/catalog"> |
|||
<input class="form-control mr-sm-2" type="search" placeholder="Search" aria-label="Search" name="search"> |
|||
<button class="btn btn-outline-success my-2 my-sm-0" type="submit" >Search</button> |
|||
</form> |
|||
</li> |
|||
<li class="nav-item" > |
|||
<a href="#" class="nav-item nav-link" ><i class="fa fa-shopping-cart" style="font-size:24px;color:white;position:absolute;right:225px;" ></i></a> |
|||
</li> <li class="nav-item dropdown" style="position:absolute;right:135px;" > |
|||
<a class="nav-link dropdown-toggle" href="#" id="navbarDropdown" role="button" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false"> |
|||
<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" fill="currentColor" class="bi bi-person-circle" viewBox="0 0 16 16"> |
|||
<path d="M11 6a3 3 0 1 1-6 0 3 3 0 0 1 6 0z"/> |
|||
<path fill-rule="evenodd" d="M0 8a8 8 0 1 1 16 0A8 8 0 0 1 0 8zm8-7a7 7 0 0 0-5.468 11.37C3.242 11.226 4.805 10 8 10s4.757 1.225 5.468 2.37A7 7 0 0 0 8 1z"/> |
|||
</svg> |
|||
</a> |
|||
<div class="dropdown-menu" aria-labelledby="navbarDropdown" > |
|||
<a class="dropdown-item" (click)="account()">Account</a> |
|||
<a class="dropdown-item" (click)="logout()">Log-Out</a> |
|||
</div> |
|||
</li> |
|||
</ul> |
|||
|
|||
</div> |
|||
</nav> |
|||
@ -0,0 +1,25 @@ |
|||
import { ComponentFixture, TestBed } from '@angular/core/testing'; |
|||
|
|||
import { NavbarComponent } from './navbar.component'; |
|||
|
|||
describe('NavbarComponent', () => { |
|||
let component: NavbarComponent; |
|||
let fixture: ComponentFixture<NavbarComponent>; |
|||
|
|||
beforeEach(async () => { |
|||
await TestBed.configureTestingModule({ |
|||
declarations: [ NavbarComponent ] |
|||
}) |
|||
.compileComponents(); |
|||
}); |
|||
|
|||
beforeEach(() => { |
|||
fixture = TestBed.createComponent(NavbarComponent); |
|||
component = fixture.componentInstance; |
|||
fixture.detectChanges(); |
|||
}); |
|||
|
|||
it('should create', () => { |
|||
expect(component).toBeTruthy(); |
|||
}); |
|||
}); |
|||
@ -0,0 +1,62 @@ |
|||
import { Component, OnInit, Output } from '@angular/core'; |
|||
import { NavigationEnd, NavigationStart, Router, RouterEvent } from '@angular/router'; |
|||
import { User } from 'src/app/model/user.model'; |
|||
import { AppserviceService } from 'src/app/service/appservice.service'; |
|||
import { UserServiceService } from 'src/app/service/user-service.service'; |
|||
import { filter } from 'rxjs/operators'; |
|||
@Component({ |
|||
selector: 'app-navbar', |
|||
templateUrl: './navbar.component.html', |
|||
styleUrls: ['./navbar.component.css'] |
|||
}) |
|||
export class NavbarComponent implements OnInit { |
|||
activate:boolean; |
|||
rou:boolean; |
|||
constructor(private route:Router,private userService:UserServiceService,private appService:AppserviceService) { |
|||
/*route.events.subscribe((val) => { |
|||
|
|||
});*/ |
|||
/* route.events.pipe(filter(e => e instanceof NavigationEnd)).subscribe((e) => {console.log("Route",e) |
|||
this.rou=e; |
|||
});*/ |
|||
this.route.events |
|||
.subscribe( |
|||
(event: any) => { |
|||
if(event instanceof NavigationStart) { |
|||
if(event.url.startsWith('/catalog')||event.url.startsWith('/product')) |
|||
this.appService.path.next(true); |
|||
} |
|||
}); |
|||
} |
|||
|
|||
ngOnInit(): void { |
|||
this.appService.activate.subscribe(data=>{ |
|||
this.activate=data; |
|||
}) |
|||
this.appService.path.subscribe(data=>{ |
|||
this.rou=data; |
|||
}) |
|||
|
|||
if(window.localStorage.getItem("isLoggedIn")){ |
|||
this.activate=true; |
|||
} |
|||
this.activate=true; |
|||
console.log("reload"); |
|||
} |
|||
account(){ |
|||
this.userService.getDetails(window.localStorage.getItem("username")).subscribe(data=>{ |
|||
console.log(data); |
|||
this.appService.userDetails.next(data); |
|||
this.route.navigateByUrl("/account"); |
|||
},(err:any)=>{ |
|||
console.log(err) |
|||
}) |
|||
} |
|||
logout(){ |
|||
window.localStorage.removeItem("auth"); |
|||
window.localStorage.removeItem("isLoggedIn"); |
|||
window.localStorage.removeItem("username"); |
|||
this.appService.activate.next(false); |
|||
this.route.navigateByUrl("/"); |
|||
} |
|||
} |
|||
@ -0,0 +1 @@ |
|||
<app-navbar></app-navbar> |
|||
@ -0,0 +1,25 @@ |
|||
import { ComponentFixture, TestBed } from '@angular/core/testing'; |
|||
|
|||
import { PagenotfoundComponent } from './pagenotfound.component'; |
|||
|
|||
describe('PagenotfoundComponent', () => { |
|||
let component: PagenotfoundComponent; |
|||
let fixture: ComponentFixture<PagenotfoundComponent>; |
|||
|
|||
beforeEach(async () => { |
|||
await TestBed.configureTestingModule({ |
|||
declarations: [ PagenotfoundComponent ] |
|||
}) |
|||
.compileComponents(); |
|||
}); |
|||
|
|||
beforeEach(() => { |
|||
fixture = TestBed.createComponent(PagenotfoundComponent); |
|||
component = fixture.componentInstance; |
|||
fixture.detectChanges(); |
|||
}); |
|||
|
|||
it('should create', () => { |
|||
expect(component).toBeTruthy(); |
|||
}); |
|||
}); |
|||
@ -0,0 +1,15 @@ |
|||
import { Component, OnInit } from '@angular/core'; |
|||
|
|||
@Component({ |
|||
selector: 'app-pagenotfound', |
|||
templateUrl: './pagenotfound.component.html', |
|||
styleUrls: ['./pagenotfound.component.css'] |
|||
}) |
|||
export class PagenotfoundComponent implements OnInit { |
|||
|
|||
constructor() { } |
|||
|
|||
ngOnInit(): void { |
|||
} |
|||
|
|||
} |
|||
@ -0,0 +1,166 @@ |
|||
|
|||
<!-- ========================= SECTION CONTENT ========================= --> |
|||
<section class="section-content padding-y bg"> |
|||
<div class="container"> |
|||
|
|||
<article class="card"> |
|||
<div class="card-body"> |
|||
<div class="row"> |
|||
<aside class="col-md-6"> |
|||
<article class="gallery-wrap"> |
|||
<div class="card img-big-wrap"> |
|||
<a href="#"> <img src="{{product.picture}}"></a> |
|||
</div> <!-- card img-big-wrap.// --> |
|||
</article> <!-- gallery-wrap .end// --> |
|||
</aside> |
|||
<main class="col-md-6"> |
|||
<article> |
|||
<a href="/catalog/{{product.category}}" class="text-primary btn-link">{{product.category}}</a> |
|||
<h3 class="title">{{product.name}}</h3> |
|||
<div> |
|||
<ul class="rating-stars"> |
|||
<li class="stars-active"> |
|||
<i class="fa fa-star"></i> <i class="fa fa-star"></i> |
|||
<i class="fa fa-star"></i> |
|||
|
|||
</li> |
|||
<li> |
|||
<i class="fa fa-star"></i> <i class="fa fa-star"></i> |
|||
<i class="fa fa-star"></i> <i class="fa fa-star"></i> |
|||
<i class="fa fa-star"></i> |
|||
</li> |
|||
</ul> |
|||
<span class="label-rating mr-3 text-muted">{{product.rating}}/5</span> |
|||
<!-- <a href="#" class="btn-link mr-3 text-muted"> <i class="fa fa-heart"></i> Save for later </a> |
|||
<a href="#" class="btn-link text-muted"> <i class="fa fa-book-open"></i> Compare </a> --> |
|||
</div> |
|||
|
|||
<hr> |
|||
|
|||
<div class="mb-3"> |
|||
<h6>Description</h6> |
|||
<ul class="list-dots mb-0"> |
|||
<li>{{product.description}}</li> |
|||
<li>Description Line Two </li> |
|||
<li>Description Line Three</li> |
|||
<li>Description Line Four</li> |
|||
</ul> |
|||
</div> |
|||
|
|||
<div class="mb-3"> |
|||
<h6>Vendor Name</h6> |
|||
<ul class="list-dots mb-0"> |
|||
<li>{{product.vendorName}}</li> |
|||
</ul> |
|||
</div> |
|||
|
|||
<!-- <div class="form-group"> |
|||
<label class="text-muted">Available sizes</label> |
|||
<div> |
|||
<label class="js-check btn btn-check active mr-1"> |
|||
<input type="radio" name="option_size" value="option1" checked=""> |
|||
<span>Small</span> |
|||
</label> |
|||
<label class="js-check btn btn-check mr-1"> |
|||
<input type="radio" name="option_size" value="option1"> |
|||
<span>Medium</span> |
|||
</label> |
|||
<label class="js-check btn btn-check mr-1"> |
|||
<input type="radio" name="option_size" value="option1"> |
|||
<span>Large</span> |
|||
</label> |
|||
<label class="js-check btn btn-check disabled"> |
|||
<input type="radio" name="option_size" disabled="" value="option1"> |
|||
<span>Babies</span> |
|||
</label> |
|||
</div> |
|||
</div> --> |
|||
|
|||
<div class="mb-3"> |
|||
<var class="price h4">₹{{product.price}}</var> <br> |
|||
<del class="price-old">₹{{product.price + 100}}</del> |
|||
</div> <!-- price-detail-wrap .// --> |
|||
|
|||
<div class="mb-4"> |
|||
<a href="javascript:void(0);" class="btn btn-primary mr-1" (click)="addToCart(product.id)">Add to Cart</a> |
|||
</div> |
|||
|
|||
</article> <!-- product-info-aside .// --> |
|||
</main> <!-- col.// --> |
|||
</div> <!-- row.// --> |
|||
</div> <!-- card-body.// --> |
|||
</article> |
|||
<!-- <article class="card mt-5"> |
|||
<div class="card-body"> |
|||
<div class="row"> |
|||
<aside class="col-md-6"> |
|||
<h5>Parameters</h5> |
|||
<dl class="row"> |
|||
<dt class="col-sm-3">Display</dt> |
|||
<dd class="col-sm-9">13.3-inch LED-backlit display with IPS</dd> |
|||
|
|||
<dt class="col-sm-3">Processor</dt> |
|||
<dd class="col-sm-9">2.3GHz dual-core Intel Core i5</dd> |
|||
|
|||
<dt class="col-sm-3">Camera</dt> |
|||
<dd class="col-sm-9">720p FaceTime HD camera</dd> |
|||
|
|||
<dt class="col-sm-3">Memory</dt> |
|||
<dd class="col-sm-9">8 GB RAM or 16 GB RAM</dd> |
|||
|
|||
<dt class="col-sm-3">Graphics</dt> |
|||
<dd class="col-sm-9">Intel Iris Plus Graphics 640</dd> |
|||
</dl> |
|||
</aside> |
|||
<aside class="col-md-6"> |
|||
<h5>Features</h5> |
|||
<ul class="list-check"> |
|||
<li>Best performance of battery</li> |
|||
<li>5 years warranty for this product</li> |
|||
<li>Amazing features and high quality</li> |
|||
<li>Best performance of battery</li> |
|||
<li>5 years warranty for this product</li> |
|||
</ul> |
|||
</aside> |
|||
</div> <!-- row.// --> |
|||
<!-- <hr> |
|||
<p> |
|||
Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod |
|||
tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, |
|||
quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo |
|||
consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse |
|||
cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non |
|||
proident, sunt in culpa qui officia deserunt mollit anim id est laborum. |
|||
</p> |
|||
</div> |
|||
</article> --> |
|||
</div> |
|||
|
|||
|
|||
</section> |
|||
<!-- ========================= SECTION CONTENT END// ========================= --> |
|||
|
|||
|
|||
<!-- ========================= FOOTER ========================= --> |
|||
<footer class="section-footer border-top padding-y"> |
|||
<div class="container"> |
|||
<p class="float-md-right"> |
|||
© Copyright 2021 All rights reserved |
|||
</p> |
|||
<p> |
|||
<a href="#">Terms and conditions</a> |
|||
</p> |
|||
</div><!-- //container --> |
|||
</footer> |
|||
<!-- ========================= FOOTER END // ========================= --> |
|||
|
|||
|
|||
|
|||
<!-- <div>Name: {{product?.name}}</div> |
|||
<div>Picture: {{product?.picture}}</div> |
|||
<div>Price: {{product?.price}}</div> |
|||
<div>Rating: {{product?.rating}}</div> |
|||
<div>Vendor Name: {{product?.vendorName}}</div> |
|||
<div>Category: {{product?.category}}</div> |
|||
<div>Description: {{product?.description}}</div> |
|||
<div>Quantity: {{product?.quantity}}</div> --> |
|||
@ -0,0 +1,25 @@ |
|||
import { ComponentFixture, TestBed } from '@angular/core/testing'; |
|||
|
|||
import { ProductComponent } from './product.component'; |
|||
|
|||
describe('ProductComponent', () => { |
|||
let component: ProductComponent; |
|||
let fixture: ComponentFixture<ProductComponent>; |
|||
|
|||
beforeEach(async () => { |
|||
await TestBed.configureTestingModule({ |
|||
declarations: [ ProductComponent ] |
|||
}) |
|||
.compileComponents(); |
|||
}); |
|||
|
|||
beforeEach(() => { |
|||
fixture = TestBed.createComponent(ProductComponent); |
|||
component = fixture.componentInstance; |
|||
fixture.detectChanges(); |
|||
}); |
|||
|
|||
it('should create', () => { |
|||
expect(component).toBeTruthy(); |
|||
}); |
|||
}); |
|||
@ -0,0 +1,32 @@ |
|||
import { Component, OnInit } from '@angular/core'; |
|||
import { ActivatedRoute } from '@angular/router'; |
|||
import { Product } from 'src/app/model/product.model'; |
|||
import { ProductService } from 'src/app/service/product.service'; |
|||
|
|||
@Component({ |
|||
selector: 'app-product', |
|||
templateUrl: './product.component.html', |
|||
styleUrls: ['./product.component.css'] |
|||
}) |
|||
export class ProductComponent implements OnInit { |
|||
|
|||
product : Product; |
|||
pid : string; |
|||
|
|||
constructor(private actRoute : ActivatedRoute, private productService : ProductService) { |
|||
|
|||
|
|||
} |
|||
|
|||
ngOnInit(): void { |
|||
this.actRoute.paramMap.subscribe(params => {this.pid = params.get('pid')}); |
|||
this.productService.getProductDetails(this.pid).subscribe(data => { |
|||
this.product = data; |
|||
}); |
|||
} |
|||
|
|||
public addToCart(id: number){ |
|||
this.productService.addItemToCart(id); |
|||
} |
|||
|
|||
} |
|||
@ -0,0 +1,11 @@ |
|||
export class Product{ |
|||
id : number; |
|||
name : string; |
|||
picture : string; |
|||
price : number; |
|||
rating : number; |
|||
vendorName : string; |
|||
category : string; |
|||
description : string; |
|||
quantity : number; |
|||
} |
|||
@ -0,0 +1,8 @@ |
|||
export class User{ |
|||
name:string |
|||
email:string; |
|||
username:string; |
|||
password:string; |
|||
address:string; |
|||
mobile:Number; |
|||
} |
|||
@ -0,0 +1,16 @@ |
|||
import { TestBed } from '@angular/core/testing'; |
|||
|
|||
import { AppserviceService } from './appservice.service'; |
|||
|
|||
describe('AppserviceService', () => { |
|||
let service: AppserviceService; |
|||
|
|||
beforeEach(() => { |
|||
TestBed.configureTestingModule({}); |
|||
service = TestBed.inject(AppserviceService); |
|||
}); |
|||
|
|||
it('should be created', () => { |
|||
expect(service).toBeTruthy(); |
|||
}); |
|||
}); |
|||
@ -0,0 +1,16 @@ |
|||
import { Injectable } from '@angular/core'; |
|||
import { BehaviorSubject } from 'rxjs'; |
|||
import { User } from '../model/user.model'; |
|||
|
|||
@Injectable({ |
|||
providedIn: 'root' |
|||
}) |
|||
export class AppserviceService { |
|||
public activate=new BehaviorSubject<boolean>(false); |
|||
public path=new BehaviorSubject<boolean>(false); |
|||
public userDetails=new BehaviorSubject<User>({email:"",username:"", |
|||
password:"", |
|||
address:"", |
|||
mobile:0,name:""}); |
|||
constructor() { } |
|||
} |
|||
@ -0,0 +1,16 @@ |
|||
import { TestBed } from '@angular/core/testing'; |
|||
|
|||
import { ProductService } from './product.service'; |
|||
|
|||
describe('ProductService', () => { |
|||
let service: ProductService; |
|||
|
|||
beforeEach(() => { |
|||
TestBed.configureTestingModule({}); |
|||
service = TestBed.inject(ProductService); |
|||
}); |
|||
|
|||
it('should be created', () => { |
|||
expect(service).toBeTruthy(); |
|||
}); |
|||
}); |
|||
@ -0,0 +1,41 @@ |
|||
import { HttpClient, HttpHeaders, HttpParams } from '@angular/common/http'; |
|||
import { Injectable } from '@angular/core'; |
|||
import { Observable } from 'rxjs'; |
|||
import { EMPTY } from 'rxjs' |
|||
import { Product } from '../model/product.model'; |
|||
|
|||
@Injectable({ |
|||
providedIn: 'root' |
|||
}) |
|||
export class ProductService { |
|||
path : string = "http://localhost:4300/apiProduct"; |
|||
cartPath : string = "http://localhost:4300/apiCart"; |
|||
|
|||
constructor(private httpClient: HttpClient) { } |
|||
|
|||
public getProductDetails(id : string){ |
|||
let product_get_url = this.path + '/product/' + id; |
|||
console.log(id); |
|||
return this.httpClient.get<Product>(product_get_url); |
|||
} |
|||
|
|||
public getAllProductsByCategory(id: string){ |
|||
if(id == undefined){return EMPTY;} |
|||
let category_get_url = this.path + '/category/' + id; |
|||
return this.httpClient.get<Product[]>(category_get_url); |
|||
} |
|||
|
|||
public searchProducts(query: string){ |
|||
if(query == undefined){return EMPTY;} |
|||
let search_get_url = this.path + '/product/search'; |
|||
return this.httpClient.get<Product[]>(search_get_url, { |
|||
params: new HttpParams().set('q', query) |
|||
}); |
|||
} |
|||
|
|||
public addItemToCart(id: number){ |
|||
let cart_get_url = this.cartPath + '/product/' + id; |
|||
console.log(id); |
|||
this.httpClient.post<any>(cart_get_url, null); |
|||
} |
|||
} |
|||
@ -0,0 +1,16 @@ |
|||
import { TestBed } from '@angular/core/testing'; |
|||
|
|||
import { UserServiceService } from './user-service.service'; |
|||
|
|||
describe('UserServiceService', () => { |
|||
let service: UserServiceService; |
|||
|
|||
beforeEach(() => { |
|||
TestBed.configureTestingModule({}); |
|||
service = TestBed.inject(UserServiceService); |
|||
}); |
|||
|
|||
it('should be created', () => { |
|||
expect(service).toBeTruthy(); |
|||
}); |
|||
}); |
|||
@ -0,0 +1,67 @@ |
|||
import { HttpClient, HttpHeaders } from '@angular/common/http'; |
|||
import { Injectable } from '@angular/core'; |
|||
import { Observable } from 'rxjs'; |
|||
import { User } from '../model/user.model'; |
|||
|
|||
@Injectable({ |
|||
providedIn: 'root' |
|||
}) |
|||
export class UserServiceService { |
|||
path:string='http://localhost:4300/apiUser'; |
|||
constructor(private httpClient:HttpClient) { } |
|||
public postUser(user:User):Observable<any>{ |
|||
let auth=btoa(user.username+":"+user.password) |
|||
user.password='' |
|||
user.username=auth |
|||
let user_api=this.path+'/user'; |
|||
return this.httpClient.post<any>(user_api,user); |
|||
} |
|||
public updateUser(user:User):Observable<any>{ |
|||
/*let auth=btoa(user.username+":"+user.password) |
|||
user.password='' |
|||
user.username=auth*/ |
|||
console.log(btoa(user.username+':'+user.password)) |
|||
let httpOptions={ |
|||
headers:new HttpHeaders({ |
|||
'Content-Type':'application/json', |
|||
'Authorization':'Basic '+window.localStorage.getItem("auth") |
|||
}) |
|||
} |
|||
let user_api=this.path+'/user/'+user.username; |
|||
window.localStorage.setItem("auth",btoa(user.username+":"+user.password)); |
|||
return this.httpClient.put<any>(user_api,user,httpOptions); |
|||
} |
|||
public getUser(user:User):Observable<any>{ |
|||
let auth=btoa(user.username+":"+user.password) |
|||
|
|||
/*user.password='' |
|||
user.username=auth*/ |
|||
window.localStorage.setItem("auth",auth); |
|||
console.log("j",user) |
|||
console.log(btoa(user.username+':'+user.password)) |
|||
let httpOptions={ |
|||
headers:new HttpHeaders({ |
|||
'Content-Type':'application/json', |
|||
'Authorization':'Basic '+btoa(user.username+':'+user.password) |
|||
}) |
|||
} |
|||
let user_api=this.path+'/login'; |
|||
return this.httpClient.get<any>(user_api,httpOptions); |
|||
} |
|||
public getDetails(user:any):Observable<any>{ |
|||
//let auth=btoa(user.username+":"+user.password)
|
|||
/*user.password='' |
|||
user.username=auth*/ |
|||
//window.localStorage.setItem("auth",auth);
|
|||
console.log("j",user) |
|||
// console.log(btoa(user.username+':'+user.password))
|
|||
let httpOptions={ |
|||
headers:new HttpHeaders({ |
|||
'Content-Type':'application/json', |
|||
'Authorization':'Basic '+window.localStorage.getItem("auth") |
|||
}) |
|||
} |
|||
let user_api=this.path+'/user/'+user; |
|||
return this.httpClient.get<any>(user_api,httpOptions); |
|||
} |
|||
} |
|||
Some files were not shown because too many files changed in this diff
Write
Preview
Loading…
Cancel
Save
Reference in new issue