Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/prosenjit-manna/wooapi
Woocommerce API with Angular. Angular woocommerce service, Wordpress auth with angular
https://github.com/prosenjit-manna/wooapi
angular angular-woocommerce angular6-library authentication woocommerce woocommerce-api wordpress wp-api wp-api-woocommerce
Last synced: about 2 months ago
JSON representation
Woocommerce API with Angular. Angular woocommerce service, Wordpress auth with angular
- Host: GitHub
- URL: https://github.com/prosenjit-manna/wooapi
- Owner: prosenjit-manna
- Created: 2018-06-03T12:38:23.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2021-09-04T15:56:02.000Z (over 3 years ago)
- Last Synced: 2024-11-11T13:08:08.649Z (about 2 months ago)
- Topics: angular, angular-woocommerce, angular6-library, authentication, woocommerce, woocommerce-api, wordpress, wp-api, wp-api-woocommerce
- Language: CSS
- Homepage: https://prosenjit-manna.github.io/wooApi/
- Size: 1.28 MB
- Stars: 39
- Watchers: 6
- Forks: 13
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
Awesome Lists containing this project
README
# WooApi
Woocommerce API service with angular## Dependency
- HttpClientModule
import { HttpClientModule } from '@angular/common/http';## Supports woocommerce API version
- Supports V2 version / V3 Version: base url https://example.com/wp-json/wc/v2 Just change the `wcEndpoint` value in environment. For the type reference If have to use github version directly to change the interface- Please see `environment` constant and interceptor for frontend setup
- https protocol is required
## Setup instruction
- [Backend setup](#backend-setup-instruction)
- [Frontend setup](#frontend-setup-instruction)## Api Doc
- https://prosenjit-manna.github.io/wooApi## Backend Setup instruction
### Enable CORS
Add this code in function.php```
add_action( 'init', 'nt_cors_enable' );function nt_cors_enable() {
header("Access-Control-Allow-Origin: " . get_http_origin());
header("Access-Control-Allow-Methods: POST, GET, OPTIONS, PUT, DELETE");
header("Access-Control-Allow-Credentials: true");
header("Access-Control-Allow-Headers: Authorization, Content-Type");
header("Access-Control-Expose-Headers: x-wc-totalpages, x-wc-total", false);
if ( 'OPTIONS' == $_SERVER['REQUEST_METHOD'] ) {
status_header(200);
exit();
}
}
```### Auth service dependency
- Install JSON API user https://wordpress.org/plugins/json-api-user/, https://wordpress.org/plugins/json-api/
- Install JWT support https://wordpress.org/plugins/jwt-authentication-for-wp-rest-api/After installatiion activate user controller from JSON-API settings. Under settings > JSON-API > User > activate.
## Frontend Setup instruction
- `npm install --save ngx-wooapi` for angular 12+
Also you can download the repo and you can use directly without NPM if you need some modification
-
- Add interceptor```
import {
Injectable,
// Injector
} from '@angular/core';
import {
HttpRequest,
HttpHandler,
HttpEvent,
HttpInterceptor,
HttpErrorResponse,
} from '@angular/common/http';
// import { Router } from '@angular/router';
import { catchError } from 'rxjs/operators';
import { Observable, throwError } from 'rxjs';// import { AuthService } from './auth.service';
import { environment } from '../environments/environment';@Injectable()
export class AppInterceptor implements HttpInterceptor {constructor(
// private injector: Injector,
// private router: Router
) { }private includeWooAuth(url) {
const wooAuth = `consumer_key=${environment.woocommerce.consumer_key}&consumer_secret=${environment.woocommerce.consumer_secret}`;
const hasQuery = url.includes('?');
let return_url = '';
if (hasQuery) {
return_url = wooAuth;
} else {
return_url = '?' + wooAuth;
}
return return_url;
}intercept(request: HttpRequest, next: HttpHandler): Observable> {
let authRequest;
// const auth = this.injector.get(AuthService);
let requestUrl = '';
if (request.url.includes('api') || request.url.includes('jwt')) {
requestUrl = `${environment.origin}/${request.url}`;
} else {
requestUrl = `${environment.origin}${environment.wcEndpoint}/${request.url}${this.includeWooAuth(request.url)}`;
}
authRequest = request.clone({
url: requestUrl
});return next.handle(authRequest)
.pipe(
catchError(err => {
if (err instanceof HttpErrorResponse && err.status === 0) {
console.log('Check Your Internet Connection And Try again Later');
} else if (err instanceof HttpErrorResponse && err.status === 401) {
// auth.setToken(null);
// this.router.navigate(['/', 'login']);
}
return throwError(err);
})
);
}
}```
Add this code in your app.module.ts
```
providers: [
{
provide: HTTP_INTERCEPTORS,
useClass: AppInterceptor,
multi: true
}
]```
Add new property in environment.ts for angular webapp```
export const environment = {
origin: 'https://example.com/appwoo',
wcEndpoint: '/wp-json/wc/v2',
woocommerce: {
consumer_key: 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx',
consumer_secret: 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx'
}
};
```Now use it in component
```
import {
WoocommerceProductsService
} from 'ngx-wooapi';constructor(
private wooProducs: WoocommerceProductsService
) { }ngOnInit() {
this.wooProducs.retrieveProducts().subscribe(response => {
console.log(response);
}, err => {
console.log(err);
});
}```
All done have fun :)
### Woocommerce Rest API doc
https://woocommerce.github.io/woocommerce-rest-api-docs/### Progress
- coupons [x]
- customers [x]
- orders [x]
- order-notes [x]
- refunds [x]
- products [x]
- product-variations [x]
- product-attributes [x]
- product-attribute-terms []
- product-categories [x]
- product-shipping-classes []
- product-tags [x]
- product-reviews [x]
- reports []
- tax-rates []
- tax-classes []
- webhooks []
- settings []
- setting-options []
- payment-gateways []
- shipping-zones []
- shipping-zone-locations []
- shipping-zone-methods []
- shipping-methods []
- system-status []
- system-status-tools []
- data []