Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/natf17/shopify-embedded-app
Enables any web app using Spring Security to operate as a Shopify embedded app.
https://github.com/natf17/shopify-embedded-app
shopify shopify-embedded-applications spring spring-boot spring-boot-2 spring-security
Last synced: 5 days ago
JSON representation
Enables any web app using Spring Security to operate as a Shopify embedded app.
- Host: GitHub
- URL: https://github.com/natf17/shopify-embedded-app
- Owner: natf17
- Created: 2019-09-20T17:15:30.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2022-12-16T14:50:06.000Z (about 2 years ago)
- Last Synced: 2024-11-13T16:43:23.271Z (about 2 months ago)
- Topics: shopify, shopify-embedded-applications, spring, spring-boot, spring-boot-2, spring-security
- Language: Java
- Homepage:
- Size: 209 KB
- Stars: 23
- Watchers: 4
- Forks: 9
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- jimsghstars - natf17/shopify-embedded-app - Enables any web app using Spring Security to operate as a Shopify embedded app. (Java)
README
# This project replaces the shopify-spring-boot-embedded-app project
This application enables any Spring web application with Spring Security to become a Shopify app and use Shopify's default OAuth offline access token.
# Running the App
- Uses Spring Security 5.2.0.RELEASE
If you're using the Spring Boot security starter, this translates to version 2.2.X.
## Obtaining Information for Your Shopify App
Once you have a development store, create a private app.1. Fill out "App name" with the name of your choice.
2. Add your "App URL":
- *https://{your-hostname}/install/shopify*
3. For "Whitelisted redirection URL(s)" add:
- *https://{your-hostname}/login/app/oauth2/code/shopify*Now that you've created your app, you're given an API key and an API key secret.
4. Copy the API key and API key secret from the Shopify site.
5. Store them, along with the desired scope, in a `.properties` file.```
ppublica.shopify.security.client.client_id=your-key
ppublica.shopify.security.client.client_secret=your-key-secret
ppublica.shopify.security.client.scope=scope1,scope2,...
```
6. Choose the password that the Spring encryptors will use to encrypt the token and add it to your `.properties` file:```
ppublica.shopify.security.cipher.password=your-password
```## Adding the project
If you're using Maven, add the following under the `` element in the pom.xml:```
com.ppublica.shopify
shopify-embedded-app
1.0.0-RELEASE
compile```
## Preparing your Application
1. Make sure your Spring/Spring Boot application can find the security beans in the jar.
```
@ComponentScan(basePackages = {"com.ppublica.shopify.security"})
```
2. Make sure the following beans are in the `ApplicationContext`:
- `MappingJackson2HttpMessageConverter`
- `JdbcTemplate`
3. Add the following to your `WebSecurityConfigurerAdapter`:
```
@EnableWebSecurity
public class WebSecurityConfig extends WebSecurityConfigurerAdapter {
@Override
protected void configure(HttpSecurity http) throws Exception {
http.authorizeRequests()
.anyRequest().authenticated().and()
.requiresChannel().and()
.oauth2Login();
}
}
```
4. Your database is expected to have the following schema:
```
|---------------------------STOREACCESSTOKENS-------------------------------|
| |
|id--storeDomain--tokenType--tokenValue--salt--issuedAt--expiresAt--scopes--|
| |
|---------------------------------------------------------------------------|
```5. Make sure you use HTTPS to comply with Shopify's security requirements.
6. Make sure your app is running and is live at the hostname you specified.
## Result
The following endpoints were registered:`/install/shopify?shop={your-store-name.myshopify.com}`:
- to log in (and install the app on the given store) either from the browser or the embedded app. This is done via Javascript redirects
- if this endpont is called by Shopify from an embedded app and the store has already been installed, the user will be authomatically authenticated (without any OAuth redirects)
- not including the `shop` parameter will force a redirect`/init`:
- this is the "login" endpoint where entering the store name in a form will call the installation endpoint with a populated `shop` parameter`/login/app/oauth2/code/**`:
- all the OAuth authentication processing happens here. This endpoint MUST be invoked by Shopify`/info`:
- a secure endpoint that displays some useful information about the app:
- apiKey: the api key for the app
- shopOrigin: the domain of the store that's currently logged in
- whether the initial login for the session was done from within an embedded app`/logout`:
- to log out# Customize the default paths
Coming soon!