Skip to content
This repository has been archived by the owner on Mar 31, 2023. It is now read-only.

[MAC manager] Improve API consistency and code refactor #183

Merged
merged 69 commits into from
May 7, 2020
Merged
Show file tree
Hide file tree
Changes from 63 commits
Commits
Show all changes
69 commits
Select commit Hold shift + click to select a range
d933b0d
[Microservices] Mac address manager
kimeunju108 Apr 6, 2020
f6316b4
[Microservices] Mac address manager - APIs create, get, delete
kimeunju108 Apr 6, 2020
e4b5604
[Microservices] Mac manager - update pom file and lib files
kimeunju108 Apr 7, 2020
336e499
[Microservies] Macmanager document update
kimeunju108 Apr 8, 2020
969841b
Revert "[Microservies] Macmanager document update"
kimeunju108 Apr 8, 2020
55d9c59
update macmanager design such as api and data structure
kimeunju108 Apr 9, 2020
677cf6e
Add design sketch for new requirements
kimeunju108 Apr 9, 2020
449d6e6
Update mac manager design doc
Apr 9, 2020
5886a77
[Microservices] Mac manager - updated unit test cases
kimeunju108 Apr 10, 2020
feb5a20
[Microservices] Mac manager - updated unit test cases
kimeunju108 Apr 10, 2020
c5dd021
Merge branch 'eunju/macmanager' of https://github.com/kimeunju108/alc…
kimeunju108 Apr 10, 2020
391ba83
Merge from featurewei/alcor master and resolve conflicts on macmanage…
Apr 10, 2020
62957d3
[Microservices] Mac manager - updated pictures and unit test cases
kimeunju108 Apr 11, 2020
935e57f
[Microservices] Mac manager - added mac range and mac address pool
kimeunju108 Apr 13, 2020
4d1f37a
Merge branch 'eunju/macmanager' of https://github.com/kimeunju108/alc…
kimeunju108 Apr 13, 2020
ca953ae
Merge branch 'master' into eunju/macmanager
Apr 14, 2020
00e766c
[Microservices] Mac manager - added macmanager service interface and …
kimeunju108 Apr 14, 2020
3f44896
Merge branch 'eunju/macmanager' of https://github.com/kimeunju108/alc…
kimeunju108 Apr 14, 2020
33466fb
[Microservices] Mac manager - add MAC range APIs and MAC allocation a…
kimeunju108 Apr 14, 2020
a86d141
Merge pull request #1 from kimeunju108/eunju/macmanager
kimeunju108 Apr 14, 2020
6f05522
[Microservices] Macmanager - combined activate/deactivate APIs to upd…
kimeunju108 Apr 15, 2020
0d23506
Fix broken maven CI workflow
Apr 15, 2020
7ca5df6
[Microservices] MAC manager - update a pom file
kimeunju108 Apr 15, 2020
2137d4c
Merge branch 'eunju/macmanager' of https://github.com/kimeunju108/alc…
kimeunju108 Apr 15, 2020
42e4ca5
[Microservices] MAC manager - added concurrent handling and comparing…
kimeunju108 Apr 17, 2020
e30c48c
[Microservices] MAC manager - added two sections: concurrent handling…
kimeunju108 Apr 17, 2020
0b852b2
[Microservices] MAC manager - updated delete API response
kimeunju108 Apr 18, 2020
3c223d9
[Microservices] MAC manager - updated activate/deactivate APIs response
kimeunju108 Apr 18, 2020
6ac310e
[Microservices] MAC manager - updated activate/deactivate APIs response
kimeunju108 Apr 18, 2020
3d3a0f4
[Microservices] MAC manager - tested APIs and matched output formaat …
kimeunju108 Apr 18, 2020
f78c95e
[Microservices] MAC manager - tested APIs and matched I/O data format…
kimeunju108 Apr 18, 2020
e44d501
[Microservices] MAC manager - tested APIs and matched I/O data format…
kimeunju108 Apr 18, 2020
d1fc282
[Microservices] MAC manager - tested and verified the design document…
kimeunju108 Apr 18, 2020
1dc52ed
[Microservices] MAC manager - tested and verified the design document…
kimeunju108 Apr 18, 2020
d0745e7
Merge branch 'eunju/macmanager', remote-tracking branch 'origin'
kimeunju108 Apr 18, 2020
44aef16
Merge remote-tracking branch 'origin' into eunju/macmanager
kimeunju108 Apr 18, 2020
325720f
Merge branch 'master' into eunju/macmanager
kimeunju108 Apr 18, 2020
d23fd98
Merge pull request #2 from kimeunju108/eunju/macmanager
kimeunju108 Apr 18, 2020
a11ec2e
[Microservices] MAC manager - resolved github conflict
kimeunju108 Apr 18, 2020
3b7355d
Merge pull request #3 from kimeunju108/eunju/macmanager
kimeunju108 Apr 18, 2020
2d0b7a9
[Microservices] MAC manager - fixed 2 pictures
kimeunju108 Apr 19, 2020
5d4f0b8
Merge pull request #4 from kimeunju108/eunju/macmanager
kimeunju108 Apr 19, 2020
a94f372
[Microservices] MAC manager - add concurrent mac creation function
kimeunju108 Apr 20, 2020
b81ade7
[Microservices] MAC manager - reviewed and corrected the design document
kimeunju108 Apr 20, 2020
59f8837
Merge pull request #5 from kimeunju108/eunju/macmanager
kimeunju108 Apr 20, 2020
a2c0c5b
[Microservices] MAC manager - synchronized redis transaction methods
kimeunju108 Apr 22, 2020
6471dbc
Merge branch 'master' of https://github.com/futurewei-cloud/alcor int…
kimeunju108 Apr 22, 2020
9a3217a
Merge pull request #6 from kimeunju108/eunju/macmanager
kimeunju108 Apr 22, 2020
3addc2e
Merge branch 'master' of https://github.com/futurewei-cloud/alcor
kimeunju108 Apr 22, 2020
485ff9e
Merge pull request #7 from kimeunju108/eunju/macmanager
kimeunju108 Apr 22, 2020
d647d13
[Microservices] Node manager - add controller, service, dao, entity, …
kimeunju108 Apr 27, 2020
2200f24
Merge branch 'master' of https://github.com/futurewei-cloud/alcor
kimeunju108 Apr 27, 2020
27f8d72
Merge branch 'master' into eunju/nodemanager
kimeunju108 Apr 27, 2020
a88e4fa
Merge pull request #8 from kimeunju108/eunju/nodemanager
kimeunju108 Apr 27, 2020
ec24cf4
Microservices] Node Manager - implemented UT and tested APIs.
kimeunju108 Apr 28, 2020
60334f2
Merge branch 'eunju/nodemanager' of https://github.com/kimeunju108/al…
kimeunju108 Apr 28, 2020
7aef537
Merge pull request #9 from kimeunju108/eunju/nodemanager
kimeunju108 Apr 28, 2020
4fbcbaf
[Microservices Node Manager - Add exception handlings
kimeunju108 Apr 29, 2020
a07e2fd
Merge pull request #10 from kimeunju108/eunju/nodemanager
kimeunju108 Apr 29, 2020
cc26ef8
[Microservices] Node Manager Part 1 - Implemented and Tested
kimeunju108 Apr 30, 2020
0e72fd3
Merge pull request #11 from kimeunju108/eunju/nodemanager
kimeunju108 Apr 30, 2020
dcd9647
Microservices] new pull from upstream
kimeunju108 May 5, 2020
03ed86c
fix pom merge conflict
May 5, 2020
b5dd1ef
[Microservices] Node manager - (1) added API that read machine config…
kimeunju108 May 7, 2020
143185b
Merge pull request #12 from kimeunju108/eunju/nodemanager
kimeunju108 May 7, 2020
dc85ee5
[Microservices] Node manager - removed
kimeunju108 May 7, 2020
68b6e01
[Microservices] Node manager - removed
kimeunju108 May 7, 2020
ce83658
[Microservices] Node manager - removed
kimeunju108 May 7, 2020
53b4f7a
[Microservices] changed pom file
kimeunju108 May 7, 2020
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Binary file modified docs/design/images/services_macrange.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file modified docs/design/images/services_macstate.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file modified docs/design/mac_manager.adoc
Binary file not shown.
Original file line number Diff line number Diff line change
Expand Up @@ -80,7 +80,7 @@ public IgniteClient igniteClientInstance() {
logger.log(Level.WARNING, "Unexpected failure:" + e.getMessage());
}

Assert.notNull(igniteClient, "IgniteClient is null");
//Assert.notNull(igniteClient, "IgniteClient is null");
kimeunju108 marked this conversation as resolved.
Show resolved Hide resolved

return igniteClient;
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@

package com.futurewei.alcor.common.repo;

import com.futurewei.alcor.common.exception.CacheException;
import com.futurewei.alcor.common.db.CacheException;
xieus marked this conversation as resolved.
Show resolved Hide resolved
import com.futurewei.alcor.common.exception.ResourceNotFoundException;

import java.util.Map;
Expand Down
1 change: 1 addition & 0 deletions pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@
<module>services/route_manager</module>
<module>services/mac_manager</module>
<module>services/private_ip_manager</module>
<module>services/node_manager</module>
</modules>
<packaging>pom</packaging>

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -22,8 +22,8 @@
import com.futurewei.alcor.common.service.RedisListener;
import com.futurewei.alcor.macmanager.entity.MacRange;
import com.futurewei.alcor.macmanager.entity.MacState;
import com.futurewei.alcor.macmanager.service.implement.RedisMacRangePublisherServiceImpl;
import com.futurewei.alcor.macmanager.service.implement.RedisPublisherServiceImpl;
import com.futurewei.alcor.macmanager.service.implement.redis.RedisMacRangePublisherServiceImpl;
import com.futurewei.alcor.macmanager.service.implement.redis.RedisPublisherServiceImpl;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.autoconfigure.domain.EntityScan;
import org.springframework.context.annotation.Bean;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,8 @@
import org.springframework.http.HttpStatus;
import org.springframework.web.bind.annotation.*;

import java.util.Collection;
import java.util.HashMap;
import java.util.Map;

import static org.springframework.web.bind.annotation.RequestMethod.*;
Expand Down Expand Up @@ -104,15 +106,15 @@ public MacStateJson updateMacState(@PathVariable String macaddress, @RequestBody
@RequestMapping(
method = DELETE,
value = {"/macs/{macaddress}", "/v4/macs/{macaddress}"})
public ResponseId deleteMacAllocation(@PathVariable String macaddress) throws Exception {
public String deleteMacAllocation(@PathVariable String macaddress) throws Exception {
String macAddress = null;
try {
RestPreconditionsUtil.verifyParameterNotNullorEmpty(macaddress);
macAddress = service.releaseMacState(macaddress);
} catch (ParameterNullOrEmptyException e) {
throw new Exception(e);
}
return new ResponseId(macAddress);
return "{mac_address: " + macAddress + "}";
kimeunju108 marked this conversation as resolved.
Show resolved Hide resolved
}

@RequestMapping(
Expand All @@ -139,22 +141,22 @@ public MacRangeJson getMacRangeByMacRangeId(@PathVariable String rangeid) throws
@RequestMapping(
method = GET,
value = {"/macs/ranges", "/v4/macs/ranges"})
public Map<String, MacRange> getAllMacRanges() throws Exception {

Map<String, MacRange> macRanges = null;
public Map<String, Collection<MacRange>> getAllMacRanges() throws Exception {
Map<String, MacRange> macRanges;
HashMap<String, Collection<MacRange>> map = new HashMap<String, Collection<MacRange>>();
try {
macRanges = service.getAllMacRanges();

} catch (Exception e) {
//TODO: REST error code
throw new Exception(e);
}

if (macRanges == null) {
//TODO: REST error code
return macRanges;
}
return macRanges;
map.put("mac_ranges", null);
} else
map.put("mac_ranges", macRanges.values());
return map;
}

@RequestMapping(
Expand Down Expand Up @@ -209,6 +211,6 @@ public ResponseId deleteMacRange(@PathVariable String rangeid) throws Exception
} catch (ParameterNullOrEmptyException e) {
throw new Exception(e);
}
return new ResponseId(rangeid);
return new ResponseId(rangeId);
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,99 @@
/*Copyright 2019 The Alcor 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

http://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.
*/
package com.futurewei.alcor.macmanager.dao;

import com.futurewei.alcor.common.db.CacheException;
import com.futurewei.alcor.common.db.CacheFactory;
import com.futurewei.alcor.common.db.ICache;
import com.futurewei.alcor.common.repo.ICacheRepository;
import com.futurewei.alcor.macmanager.entity.MacRange;
import com.futurewei.alcor.macmanager.entity.MacState;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.stereotype.Repository;

import javax.annotation.PostConstruct;
import java.util.HashMap;
import java.util.Map;

@Repository
@ComponentScan(value = "com.futurewei.alcor.common.db")
public class MacRangeRepository implements ICacheRepository<MacRange> {
private static final Logger logger = LoggerFactory.getLogger(MacRangeRepository.class);
private ICache<String, MacRange> cache;

@Autowired
public MacRangeRepository(CacheFactory cacheFactory) {
cache = cacheFactory.getCache(MacRange.class);
}

public ICache<String, MacRange> getCache() {
return cache;
}

@PostConstruct
private void init() {
logger.info("MacRangeRepository init: Done");
}

@Override
public MacRange findItem(String rangeId) throws CacheException {
MacRange macRange = null;
try {
macRange = cache.get(rangeId);
} catch (CacheException e) {
logger.error("MacRangeRepository findItem() exception:", e);
throw e;
}
return macRange;
}

@Override
public Map<String, MacRange> findAllItems() throws CacheException {
HashMap<String, MacRange> hashMap = new HashMap<String, MacRange>();
try {
hashMap = new HashMap(cache.getAll());
} catch (CacheException e) {
logger.error("MacRangeRepository findAllItems() exception:", e);
throw e;
}

return hashMap;
}

@Override
public void addItem(MacRange macRange) throws CacheException {
try {
cache.put(macRange.getRangeId(), macRange);
logger.info("MacRangeRepository addItem() {}: ", macRange.getRangeId());
} catch (CacheException e) {
logger.error("MacRangeRepository addItem() exception:", e);
throw e;
}
}

@Override
public void deleteItem(String rangeId) throws CacheException {
try {
cache.remove(rangeId);
logger.info("MacRangeRepository deleteItem() {}: ", rangeId);
} catch (CacheException e) {
logger.error("MacRangeRepository deleteItem() exception:", e);
throw e;
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -15,29 +15,29 @@

package com.futurewei.alcor.macmanager.dao;

import com.futurewei.alcor.common.exception.CacheException;
import com.futurewei.alcor.common.logging.Logger;
import com.futurewei.alcor.common.logging.LoggerFactory;
import com.futurewei.alcor.common.repo.ICache;
import com.futurewei.alcor.common.db.CacheException;
import com.futurewei.alcor.common.db.CacheFactory;
import com.futurewei.alcor.common.db.ICache;
import com.futurewei.alcor.common.repo.ICacheRepository;
import com.futurewei.alcor.common.service.CacheFactory;
import com.futurewei.alcor.macmanager.entity.MacState;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.autoconfigure.condition.ConditionalOnBean;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.stereotype.Repository;

import javax.annotation.PostConstruct;
import java.util.HashMap;
import java.util.Map;
import java.util.logging.Level;

@Repository
@ConditionalOnBean(CacheFactory.class)
public class MacRepository implements ICacheRepository<MacState> {
private static final Logger logger = LoggerFactory.getLogger();
@ComponentScan(value = "com.futurewei.alcor.common.db")
public class MacStateRepository implements ICacheRepository<MacState> {
private static final Logger logger = LoggerFactory.getLogger(MacStateRepository.class);
private ICache<String, MacState> cache;

@Autowired
public MacRepository(CacheFactory cacheFactory) {
public MacStateRepository(CacheFactory cacheFactory) {
cache = cacheFactory.getCache(MacState.class);
}

Expand All @@ -47,28 +47,52 @@ public ICache<String, MacState> getCache() {

@PostConstruct
private void init() {
logger.log(Level.INFO, "MacRepository init completed");
logger.info("MacState repository init: Done");
}

@Override
public MacState findItem(String macAddress) throws CacheException {
return cache.get(macAddress);
MacState macState = null;
try {
macState = cache.get(macAddress);
} catch (CacheException e) {
logger.error("MacStateRepository findItem() exception:", e);
throw e;
}
return macState;
}

@Override
public Map findAllItems() throws CacheException {
return cache.getAll();
HashMap hashMap = new HashMap();
try {
hashMap = new HashMap(cache.getAll());
} catch (CacheException e) {
logger.error("MacStateRepository findAllItems() exception:", e);
throw e;
}
return hashMap;
}

@Override
public void addItem(MacState macState) throws CacheException {
logger.log(Level.INFO, "Add mac state, mac_state:" + macState.getMacAddress());
cache.put(macState.getMacAddress(), macState);
try {
cache.put(macState.getMacAddress(), macState);
logger.info("MacStateRepository addItem() {}: ", macState.getMacAddress());
} catch (CacheException e) {
logger.error("MacStateRepository addItem() exception:", e);
throw e;
}
}

@Override
public void deleteItem(String macAddress) throws CacheException {
logger.log(Level.INFO, "Delete mac state, mac address:" + macAddress);
cache.remove(macAddress);
try {
cache.remove(macAddress);
logger.info("MacStateRepository deleteItem() {}: ", macAddress);
} catch (CacheException e) {
logger.error("MacStateRepository deleteItem() exception:", e);
throw e;
}
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@
See the License for the specific language governing permissions and
limitations under the License.
*/
package com.futurewei.alcor.macmanager.dao;
package com.futurewei.alcor.macmanager.dao.redis;

import com.futurewei.alcor.common.logging.Logger;
import com.futurewei.alcor.common.logging.LoggerFactory;
Expand Down Expand Up @@ -46,32 +46,36 @@ private void init() {
}

@Override
public String findItem(String value) {
public synchronized String findItem(String value) {
if (setOperations.isMember(KEY, value))
return value;
else
return null;
}

@Override
public Map findAllItems() {
public synchronized Map findAllItems() {
return (Map) setOperations.members(KEY);
}

@Override
public void addItem(String newItem) {
public synchronized void addItem(String newItem) {
Logger logger = LoggerFactory.getLogger();
logger.log(Level.INFO, newItem);
setOperations.add(KEY, newItem);
if (setOperations.isMember(KEY, newItem) == false)
setOperations.add(KEY, newItem);
}

@Override
public void deleteItem(String value) {
public synchronized void deleteItem(String value) {
setOperations.remove(KEY, value);
}

public String getItem() {

public synchronized String getItem() {
return (String) setOperations.randomMember(KEY);
}

public synchronized long getSize() {
return setOperations.size(KEY);
}
}
Loading